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A METHOD AND APPARATUS FOR PREPARATION OF A DATABASE 
DQCOMENT IN A LOCAL PROCESSING APPARATUS AND LOADING OF 
THE DATABASE DOCUMENT WITH DATA FROM REMOTE SQTIRCES 

The present invention relates to a system and 
5 method for obtaining and collating information from a 
plurality of computer users. More particularly, but not 
exclusively, the invention relates to a method and system 
for asking questions of computer users having access to 
electronic mail, and to a method and system for collating 

10 their responses and presenting them in a database. 

In recent years, developments in communication 
systems and computer technology have enabled 
communication between computers over vast distances 
utilising communications networks. Employing electronic 

15 mail and like systems, it is possible for a user of a 
personal computer (or any other type of computer) with 
access to a modem or other network communications 
interface, to communicate with any number of users of 
remote computers e.g., via the internet. Distance is no 

20 barrier- Further, in small or large companies electronic 
mail networks are often used to connect user terminals to 
enable communication in-house between users. 

The possibility of communication with any number 
of users having access to electronic mail opens up vast 

25 information gathering potential. 

To obtain and process such large amotmts of 
information, however, presents a number of problems. 
Using electronic mail and like systems task for a user 
of a computer may ask a question or questions of a 

30 relatively large number of remote users, by addressing 
mail including a question or questions to those users. 

The task of processing responses to the question 
or questions becomes extremely difficult. Where a large 
number of users provide responses, the task can be almost 

35 impossible. This difficultly will be aggravated where a 
large number of (questions are asked. The amount of 
information to process can be staggering and the user who 
asked the questions may be faced with the onerous task of 
sorting through a large amount of mail, item by item, to 
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extract and collate the information he requires. Wh^re a 
large amount of information is required from a large 
number of people, it is impractical for one person to 
deal with. 

5 Consider the example of opinion polls, whether 

for marketing, political or other purposes. Presently, 
large numbers of field operators are required to gather 
numerous responses from members of the public. Once 
those responses have been gathered, hundreds and even 
10 thousands of man-hours are required to process the 
responses to extract the required information and present 
it in a form which allows for analysis. Thousands of 
quest ionaries may need processing, each with many 
questions and responses. It should also be noted that 
15 the time taken to gather and process the responses can 
mean that the information finally revealed from the 
opinion poll has lost it's relevance or at least become 
less relevant. Consider a political opinion poll, where 
peoples opinions may be varying from day to day, 
20 significantly enough to affect the election result. An 
opinion poll which takes two or three days to process 
will be out of date and irrelevant by the time the 
results are available for publication. 

There are really two major problems with 
25 presently available "surveying". Firstly,* there is the 
problem of how does a person ask the questions of all the 
people he wishes to ask the questions of, without 
expending many man hours or employing a number of people 
as field operators? This problem is somewhat alleviated 
30 by the existence of systems such as electronic mail, 
which enable a person to select a number of people to 
send a single document to. There is the problem here, 
however, that no convenient means exists of asking a 
series of complex, linked questions. For example, a 
35 persons answer to a particular question may determine 
whether or not a subsequent question is relevant to that 
person. If the person is asked whether they are taking 
leave from employment that year to go on holiday, and 
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answer no, there is no point in asking them where' they 
are going on holiday. Electronic mail like commiinication 
systems do not deal with that problem. 

Even though electronic mail and like 
5 communication systems may be used to somewhat alleviate 
the problem of getting a question to a number of people, 
such systems do nothing to alleviate the problems 
associated with processing the answers. There is no 
alternative but for the person asking the question to 

10 sort through return mail item by item to, first of all, 
identify which mail is in response to his questions, and, 
then, to collate and process the responses to enable a 
meaningful analysis. 

These problems are not limited to large surveys, 

15 such as political opinion polls. Even quite small 
surveys can present problems of time management. For 
example, imagine if a director of a company with fifty or 
so en^loyees wishes to plan staff leave for the year. He 
has to ask all his employees when they would like to take 

20 leave. He may also wish to know where they want to go. 
He can do this by sending out a memo and awaiting the 
results, or perhaps even sending out a memo on intra 
office computer mail and awaiting the results. He still 
has to process all the results. Processing results, 

25 analysing them and planning the leave even of only fifty 
people can be quite time consuming, particularly for a 
person with mainy other responsibilities who does not 
really have the time to spend on such a task. Further, 
the managing director may wish to ask many different 

30 types of c[uestions o£ his staff on a on-going day-to day 
basis. His only option for processing the responses is 
to do it himself, item by item, or, if he has not got 
time (as is usually the case) to employ somebody to do 
it. 

35 In a preferred embodiment, the present invention 

advantageously provides a way of asking a question of any 
number of users, preferably via electronic mail or an 
equivalent communications media, and automatically 
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receiving, identifying and processing responses to* the 
question. 

From a first aspect, the present invention 
provides A system for obtaining information from a 
5 plurality of computer users: 

comprising a processing apparatus including an 
input means via which a survey author may input data, and 
a survey authoring means enabling construction of a 
survey questionnaire document including at least one 
10 question formulated from data input by the survey author; 

transmission means for transmitting the survey 
questionnaire document to a plurality of respondent 
users ; and 

a processing apparatus including a collating 
15 means arranged to receive transmissions from the 
transmission means, to identify response documents which 
include responses to the at least one question from the 
plurality of respondent users and to load a database in 
accordance with the responses. 
20 A "survey author" is any person who wishes to 

use the survey document authoring means to construct a 
survey questionnaire document . 

The transmission means is preferably electronic 
mail. Please note that the terminology electronic mail 
25 is not only used in a narrow sense, but used in a more 
general sense, to mean any way of communicating between 
computer users utilising telecommunications media 
(telephone, optical fibre, satellite, etc.) which enables 
a user or group of users or a location e.g., a "relative" 
30 location such as a "bulletin board" to be designated by 
an address, preferably a unique address. The 
transmission means may even include transmission of 
floppy disks including the response document, by ordinary 
mail, although this is not preferable. 
35 Where electronic mail is employed, the collator 

means is preferably arranged to monitor all electronic 
mail being received by the processing apparatus in which 
the collator means is included, to sort the electronic 
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mail to identify response documents. Electronic mail not 
including a response document is not processed any 
further by the collation means. Where a response 
document is identified, further processing takes place. 
5 Preferably, the further processing includes locating the 
database which is to receive the responses to the survey 
document, and loading the database in accordance with the 
responses . 

In at least preferred embodiments, the apparatus 

10 and method of the present invention advantageously 
enables the user of a processing apparatus such as a 
computer to prepare a survey document asking for 
information on any subject he desires, utilising at least 
one question or any number of questions determined by the 

15 user, to transmit the survey document to any number of 
remote processing apparatus, preferably by electronic 
mail, to receive and automatically collate response 
documents containing or specifying responses to the 
survey document provided by users of the remote 

20 processing apparatus to which the survey document is 
transmitted, and loading the database with answers, so 
that the answers are all conveniently presented in a 
database for subsequent analysis. 

The invention preferably provides the ability to 

25 gather information very easily and quickly over vast 
distances and to automatically present the information in 
an already-collated and format. It can be used for any 
number of information gathering applications. 

The information obtained by embodiments of this 

30 invention is preferably "fresh". It can be obtained very 
quickly and is therefore more likely to be relevant than 
information obtained by prior art methods, such as 
opinion polling. Because the information is 

automatically processed and presented in a database, 

35 there is no need to \indertake the laborious job of 
individually processing each response docixment. An 
immense amount of time can be saved. Because of the 
automatic collation, a single survey author may poll 
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thousands of respondent users, their responses being 
processed for him automatically almost as soon as they 
arrive- It can be considered akin to the survey author 
simultaneously having a * conversation" with thousands of 

5 people. Instead of the responses being a jumble of 
noise, as it would in a real life conversation with such 
a crowd, the user receives the information presented in 
an immediately understandable format of his choice. 

The database used may be any type of computer 

10 data storage arrangement. It may be a relational 
database or series of databases of the type presently 
known. The database preferably includes a plurality of 
fields for receiving answers dictated by the responses. 
Bach database field for an answer is preferably uniquely 

15 identified by a column label, which may relate to the 
question asked, and a **row" label which relates to the 
identity of the respondent user. The terms "columns" and 
"rows" are not used in any limited sense to indicate that 
all the databases are physically matrixes (although they 

20 can be represented that way) , but to indicate that each 
answer field has a unique identifier. The row label is 
preferably the electronic mail name and address of the 
respondent user. One or more "columns" in the database 
may be required to contain the row electronic mail 

25 address. 

Note that the possibility exists of allowing for 
more than one answer by the same user to the same survey 
document. For example, a respondent user may be asked to 
answer the survey document every week. In that case, the 
30 system may be arranged to override the previous weeks 
data field values or add a further row, including the 
latest response and identifying it by date and time of 
response as well as electronic mail name and address. 

The data base field values may be derived from 
35 the response provided by the respondent user or may 
actually be the response provided by the respondent user, 
e*g., where the response is text information. 

Once the database has been loaded with values. 
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then the information can be manipulated in any way the 
user requires, utilising all the database facilities. 
For example, graphical plots may be made of responses. 

A particular advantage of using E-Mail is that 
5 it is possible to store the address of respondent users 
in the database, for later use. It would then, for 
example, be possible to mail back further questions to 
persons giving a particular response to one or more 
questions in a previous survey document. For exanqple, if 

10 a particular survey question was "Do you like chocolate", 
and half the respondents said yes and the other half said 
no, it would be possible to prepare a further survey 
document asking; "Would you like to have a free sample 
of our new chocolate bar brand X", and only mail it to 

15 the respondent users who said "yes" to liking chocolate. 
Using the properties of databases the second survey 
document could be prepared and transmitted very quickly, 
merely by instructing the processing appeuratus that the 
survey document is only to go to those people that said 

20 yes to the "Do you like chocolate?" question. This 
illustrates the "conversational" advantages of at least 
preferred embodiments of this invention, as discussed 
previously. It is possible to obtain responses from 
people in a very short time period and use the 

25 information from those responses to ' ask further 
questions. 

The system therefore preferably has the ability 
to nail two respondents of previous surveys, to 
facilitate this "conversational" style of commxinication. 

30 Note that the process of "conversation" may be 
particularly important when the analysed data shows a 
trend that the Survey Author did not expect and did 
therefore not include any questions to cover this 
eventuality. He can produce further survey documents to 

35 send to the respondents including those questions that he 
did not include in the first place. Conversation is 
further facilitated by the ability to choose which 
respondents to mail to, may be depending upon their 
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responses to previous questions, combined with^ the 
ability to store electronic mail name and address lists 
o£ respondents. 

The database is preferably created automatically 
5 by the survey authoring means, preferably when the survey 
document has been completed, and, more preferably, 
immediately before transmission of the survey document. 
It is not generally necessary for the user to input any 
data specifically to prepare the database, although a 

10 facility is preferably available to enable the user to 
choose labels for database columns and/or rows. 

As the survey author constructs the survey 
document, the survey preparation means is preferably 
arranged to allow labels for database columns to be 

15 inserted. If the user does not wish to insert any labels 
himself, the survey document preparation means is 
preferably arranged to select the headings itself, i.e., 
by default. 

The database is preferably constructed as a 
20 matrix, having at least one question column and a 
plurality of user rows, the rows and columns specifying a 
plurality of database answer fields for receipt of 
answers (being derived from the respondent users 
responses) to the at least one question, each row being 
25 associated with a particular respondent user who may 
receive or has received the survey document and may 
provide or has provided an answer document (response 
document). The question colunui is associated with the at 
least one question aslced. It will be appreciated, as 
30 discussed above that the matrix format is preferred, but 
it will also be appreciated that the invention extends to 
cover any type of database structure. 

The survey questionnaire document or a subset 
thereof may be stored to enable re -transmission of the 
35 survey document at a later stage, as a reminder should 
any of the pre -selected users not have provided a 
response document. The database is also preferably 
constructed just prior to transmission. Where the 
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respondent user identities are kno%m the entire dat^ase 
may be constructed (pre-populated) . 

It will be appreciated that the option does 
exist of constructing a database as answer documents are 
5 received and processed, e.g., a particular user row will 
only be added when an answer document is processed. This 
embodiment may have applications where, for example, the 
survey document is posted on a ••bulletin board*' for use 
by any persons who wish to answer the survey. Each row 

10 or row label will therefore only be added as responses 
come in and are processed by the collation means. The 
response document preferably includes an identifier 
identifying the database survey it belongs to, so that 
the collation meams can load the appropriate database 

15 with the response and construct a further row label. 

The use of electronic mail enables selection of 
any type of user, group of users, posting on a bulletin 
board, etc. 

By "user** is meant any natural person or group 

20 of persons, company or generally an "identity" who may be 
specified by the survey author. 

The survey document may be saved on a respondent 
users system this enables the remote user (respondent 
user) to send responses back to the collator when and as 

25 often as desired. This could be useful in any 
circumstances where data is collected on a regular basis. 
For example, recording telephone sales inquiries. 

The survey document may include any number of 
questions and may also include branched-to questions 

30 linked to another question or questions such that the 
branched-to question or questions will only be required 
to be answered by a respondent user if the respondent 
(remote user) user gives a predetermined answer to the 
question or series of questions to which the branched- to 

35 question is linked. A survey document may include a 
string of questions linked to each other and the 
branched-to question or questions may be asked if the 
remote user has given one or more predetermined answers 
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to the string o£ questions and to the question to Which 
the branched-to question is linked. In a preferred 
embodiment I the survey document is presented to the 
respondent user as a plurality of screens (where there 
5 are a plurality of questions) , each screen asking, 
generally f one question. A screen presenting a 
branched- to (juestion will not be presented by the display 
to the remote user unless he makes one or more 
predetermined answers to a previous question or 

10 questions. Whether a branched-to question is presented 
may also depend on whether another or other questions 
have been presented or will be presented to the remote 
user (respondent user) . In other words, if the 
respondent users answers have meant that he has 

15 "bypassed** a question or questions, then a particular 
branched- to (question may be presented. Note that it is 
also possible to ask a number of questions on a single 
screen and whether a particular question is presented may 
depend on his answer or combination of answers to any one 

20 or more of these questions. The survey document in 

this preferred embodiment is "dynamic**, in the sense that 
it will only present questions to a respondent user if 
the respondent user has made a predetermined answer or 
answers to a linked question or questions. The survey 

25 document will guide the respondent user on a path through 
the document which is determined by the respondent users 
answers. Questions which are not relevant to the 
respondent user, as determined by his answers to other 
questions, will never be asked of the respondent user. 

30 This has the advantage that it is not necessary for the 
respondent user to wade through a series of displayed 
questions to find the ones that are relevant to him. He 
will be automatically guided through the document. It 
saves time. 

35 The survey authoring means preferably includes a 

branch control means which enables construction of a 
complex linked survey document structure on the basis of 
data input by the survey author. The branch control 
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means includes branch control operator commands which are 
selectable by the survey author to govern the link 
structure. These are a tools which the survey author can 
use to construct a complex document with many pathways 
5 through it* 

Preferably, the step of preparing the survey 
document includes specifying an allowaUble smswer or a 
plurality of allowable answers to the at least one 
question, so that remote users of may specify at least 

10 one of the allowable answers, when processing the survey 
document on their computer (s) . Preferably, a database 
field value is specified for each allowable answer. In a 
preferred embodiment, when the answer document is 
processed, the database field value is entered in the 

15 appropriate database field. 

The field value may be comprised of numeric or 
alphanumeric characters, may be any desired symbol or 
symbols. In a preferred embodiment, the specified field 
value for a' particular question may be generated 

20 automatically from components of the question itself, 
components of the allowable answer, or may be an 
automatically generated default. 

The allowad^le answers in some cases may be text 
to be inserted by the respondent user. In these cases, a 

25 length for the allowable text may be specified by the 
survey author. The database field value will be whatever 
text the respondent user inputs, within the allowable 
field length. This allows for anything from simple 
answers to more complicated text answers. 

30 Where a question or questions is not asked of a 

particular user, i.e., it may have been bypassed because 
the users responses to other questions in the survey 
document meant that it was not appropriate for him to be 
asked that question or (juestions (see above) then, 

35 preferably, a "never seen" value is entered in the 
appropriate database field on collation. 

The person accessing the database can therefore 
see at a glance whether or not a particular user actually 
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"saw" a particular question. The never-seen value may 
include any choice of character or group of characters 
and may be specified by the survey author or as a default 
by the survey document preparation means. 
5 The step of preparing the plurality of allowable 

answers may include preparing a grid, having rows and 
columns providing a matrix of cells for receiving the 
allowable answers. A title head is preferably prepared 
for each row and column in the matrix. 
10 In a preferred embodiment, there are three types 

of grids which may be applied. An option buttons grid, a 
numeric field grid and a check box grid. 

For an option buttons grid only one question 
column is generally required in the database even though 
15 there may be a plurality of cells in the grid for 
receiving the allowable answers. Preferably, the field 
values associated with each allowable answer are taken 
from components of the row and/or column heading for each 
particular cell. Option button grids may also be 
20 provided including sub-groups of option buttons each 
requiring an answer. In this case, there will be as many 
question columns in the database as there are groups of 
option buttons requiring an answer. The groups are 
preferably in rows and columns. 
25 For numeric field grids and check box grids, in 

the preferred embodiment a question column in the 
database is required for each cell of the grid. The 
headings of these question columns may preferably be 
formed from components of the row and/or column head of 
30 the grid. 

Preferably, the step of preparing the Survey 
Document further includes the step of scanning the Survey 
Document when it has been completed by the survey author 
and identifying any errors in the question structure, 
35 utilising a scan test means included in the processing 
apparatus including the survey authoring means. 
Generally, each question in the Survey Document must come 
from at least one previous question and lead to at least 
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one further question « apart from the first and * last 
questions in the Survey Document which will come from the 
start of the document (N.B., the first question will be 
designated by the author of the document. In fact, in 
5 the preferred embodiment, it is open to the author to 
formulate the questions first and then designate their 
sequence in the structure of the document separately) and 
lead to "finish", respectively. In a complex document 
including branched- from and branched- to questions there 

10 will be a number of different "pathways" through the 
Survey Document. It will be appreciated that the 
structure can be extremely complex. It is quite possible 
that during preparation of the Survey Document, the local 
user (the survey author) will make an error in 

15 preparation which will lead to one or more of the 
pathways being incomplete or broken, i«e., a question 
exists (other than the first question) which does not 
come from any other question (an "orphan") or which does 
not lead from all the questions it is supposed to lead 

20 from, and questions may exist which do not lead to any 
other question ("cul-de-sacs") or do not lead to all the 
questions they are supposed to lead to. Any such errors 
should be identified before the Survey Document is 
transmitted. This is preferably done by applying a scan 

25 test function, which scans through all the pathways in 
the document to identify errors, particularly of the 
"orphan" or "cul-de-sac" type, although it may identify 
other "mechanical" errors of this type which may lead to 
breakdo%m of pathway in the Survey Document. The scan 

30 test means applying the scan test function will also test 
for missing, duplicate and illegal database names (e.g., 
the database name not allowed by the particular database 
which is being constructed, e.g., in DOS only eight 
characters are allowed for a database name) . 

35 The scan test function preferably also provides 

a display listing of all the variable information in the 
Survey Document, variable information generally being any 
item in the document that the local user may exercise a 
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choice in selecting, for example, "Goto's", whethejf the 
question is branched to or not, database field titles, 
etc., but does not display, in general, any textual 
information from the question content of the Survey 
5 Document. The listing enables the local user to check 
that the mechanical structure of the document (the 
pathways leading through the Survey Document) is correct, 
by visually checking the listing. Further, in one 
embodiment, the items in which errors have been 

10 identified are indicated in the listing, preferably by 
highlighting these particular items. By clicking on any 
of the items on his screen the local user will 
automatically be taken to the actual item. It is 
therefore possible for him to easily be able to check the 

15 document and correct any errors indicated. 

In the preferred embodiment, the steps of 
preparation of survey questionnaire document, 
transmission, processing of the survey document by a 
respondent user (remote user) return of the survey 

20 document to the collation means and collator, operate as 
follows: 

1. A survey master document is originally 
constructed and includes operator commands for 
controlling the display of the respondent users 

25 computer to display questions, and, in response 

to the remote users input, to display selected 
ones of the questions depending upon the linkage 
structure of the document. It also includes a 
return E-Mail address for the collation means. 

30 E-Mail addresses of respondent users are 

inserted prior to transmission. The database is 
constructed from instructions input by the 
survey author and/or defaults. The survey 
questionnaire document (preferably a subset of 

35 the master) is transmitted and at the same time 

saved so that reminders can be transmitted if 
required (note the survey document is preferably 
transmitted as a "subset" SVQ, of the originally 
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prepared master, sum, and it is the SVQ whit:h is 
stored) . In one preferred embodiment, the 
survey document is transmitted with respondent 
control means, used to control the respondents 
5 terminal to run the survey document. In an 

alternative embodiment, a respondent control 
means is pre-loaded on the respondents computer, 
and is arranged to control the respondents 
terminal to process a survey document when one 
10 is received. 

At this time the database is preferably 
constructed. 

2. The respondent users terminal is controlled from 
commands in the survey document and the 

15 respondent control means to process the survey 

document and produce a response document which 
includes responses based on data input by the 
respondent user. The response document is 
automatically transmitted back to the collation 

20 means address on completion of a response by the 

respondent user. The survey response document 
may include a database construction means which 
enables construction of the database. This is 
useful where a disaster has occurred and the 

25 database has "crashed", for some reason. It may 

also be useful where the collator has moved 
location and does not have access to the 
database or does not know the databases address. 

3. The collation means monitors electronic mail at 
30 the processing address including the collation 

means and identifies response documents. It 
checks the identifier including the response 
document to identify the database it belongs to. 
It then locates the appropriate database and 
35 commences to process the survey document to load 

the database with answers determined by the 
respondent users responses. 

Note that the collation means and survey author 
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may be on separate processing apparatus. The aarvey 
author may also be a different person from the person who 
is accessing the database to obtain the information. For 
example, the survey author may be a pollster employee, 
5 and the person accessing the information may be the 
pollster. The survey author can put together the surveys 
on the basis of instructions provided by the pollster as 
to what type of information he wants. All the survey 
author needs to know about the collation means is the 

10 collation means electronic mail address. The database 
may be loaded on the same processing apparatus as the 
collation means or on any other processing apparatus. 

The collation means may be collating any number 
of surveys. It may collate surveys for any number of 

15 survey authors. 

The response document may be encrypted for 
security reasons. 

Preferably, the collation means is also arranged 
to identify electronic mail addresses of respondent users 

20 from response documents are attached messages and to load 
the database with the electronic mail addresses. These 
electronic mail addresses can then be easily accessed for 
future surveys. 

Where a range of databases are used, a great 

25 deal of information can be obtained over time about a 
particular respondent user who has received a number of 
surveys - 

All "documents" are preferably in "data 
processing representation" form. In other words, they 

30 are in an electronic or other form able to be manipulated 
by a data processing apparatus, e.g., a computer, and, in 
some aspects, to control a computer. By "computer" is 
meamt any processing apparatus which is able to 
manipulate data. This includes computers which use other 

35 means apart from electrical signals to process data. 

Prom a second aspect, the present invention 
provides a processing apparatus for enabling construction 
of a survey (juestionnaire document, comprising an input 
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means via which a survey author may input data^ a survey 
authoring means enabling construction of a survey 
questionnaire document including at least one question 
formulated from data input by the survey author and a 
5 location address of a processing apparatus including a 
collator means arranged to collate response documents 
produced by respondent users processing the survey 
questionnaire document. 

The survey authoring means may include any or 
10 all of the features of the survey authoring means 
discussed above, for preparing a survey document with any 
or all of the features of the survey document discussed 
above* 

From a third aspect, the present invention 
15 provides a survey cjuestionnaire document structure, the 
document being employable by digital document processing 
systems to gather information from a plurality of 
respondent computer users, the document structure 
including: 

20 a location address for a collation means for 

receiving response documents to the survey questionnaire 
document from respondent users; and 

instructions enabling control of a computer to 
display one or more questions to be answered by a user. 

25 Prom a fourth aspect the present invention 

provides .a processing apparatus for collating response 
documents received from a plurality of respondent users 
in response to their receiving a survey questionnaire 
document from a processing apparatus, including a 

30 collator means arranged to monitor incoming transmissions 
from a transmission means and identify response 
documents, which include responses and to load a database 
in accordance with the responses. 

Prom a fifth aspect the present invention 

35 provides a processing apparatus for receiving and 
processing survey questionnaire documents produced by an 
apparatus, including a respondent control means arranged 
to process the survey questionnaire document in 
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accordance with data input by a respondent user, to 
produce a response document including a response to the 
at least one question. 

Prom a sixth aspect the present invention 
5 provides a computer-readable memory including a set of 
instructions for enabling a processing apparatus to 
enable construction of a survey questionnaire document, 
the document being employed to gather information from a 
plurality of respondent users, the instructions enabling 
10 the computer to operate as a survey authoring means 
enabling construction of a survey document including at 
least one question formulated from data input to the 
computer by a survey author, and a location address for a 
collation means for receiving and collating response 
15 documents respondent users in response to their 
processing the survey questionnaire document. 

From a seventh aspect the present invention 
provides a computer- readable memory storing a set of 
instructions that can be used to direct a processing 
20 apparatus to operate as a collator means, for collating 
response documents in response to a survey cjuestionnaire 
document produced by a processing apparatus, the 
instructions operating the processing apparatus to 
monitor incoming transmissions for response documents, 
25 and to load a database in accordance with responses. 

From an eighth aspect the present invention 
provides a computer-readable memory storing a set of 
commands that can be used to direct a processing 
apparatus to process a survey questionnaire document 
30 produced by the apparatus, to produce a response document 
including a response to the at least one question, to be 
transmitted on a location for a collation means for 
collating responses. 

Prom a ninth aspect the present invention 
35 provides a method of obtaining information from a 
plurality of computer users, comprising operating a 
processing apparatus including an input means via which a 
survey author may input data, to construct a survey 
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questionnaire document including at least one question 
formulated from data input by the survey author, 
transmitting the survey document to a plurality of 
respondent users, and controlling a processing apparatus 
5 to carry out a collation operation including the steps of 
receiving transmissions from respondent users, 
identifying response documents including responses from 
the plurality of respondent users, and loading a database 
in accordance with the responses. 
10 The tenth aspect of the present invention 

provides a method of controlling a processing apparatus 
to construct a survey questionnaire document for 
obtaining information from a plurality of respondent 
users, the method comprising the steps of: 
i5 controlling the processing apparatus to 

construct a survey questionnaire document including at 
least one question formulated from data input to the 
processing apparatus by a survey author; and 

to include a location address of a processing 
20 means for collating responses to the survey from 
respondent users to load a database in accordance with 
the responses. 

The eleventh aspect of the present invention 
provides a method of collating response documents 
25 prepared by respondent users in response to a survey 
document in accordance with claims 67 or 68, the method 
comprising the steps of: 

controlling a processing apparatus to monitor 
incoming transmissions to the processing apparatus and 
30 identify response documents to the survey, and to process 
the response documents to load a database in accordance 
with the responses to the at least one question. 

The thirteenth aspect of the present invention 
provides a method of controlling a processing apparatus 
35 to process a survey questionnaire document produced, to 
produce a response document formulated from data input by 
a respondent user, the method comprising the steps of: 

controlling the processing apparatus to display 
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the at least one question for input of a response by the 
respondent user; and 

controlling the respondents computer to prepare 
a response document for transmission to the collating 
5 processor . 

Features and advantages of the present invention 
will become apparent from the following description of an 
Features and advantages of the present invention will 
become apparent from the following description of an 
10 embodiment thereof, by way of example only, with 
reference to the accompanying drawings, in which: 

Figure 1 is a schematic block diagram of a 
system in accordance with an embodiment of the present 
invention incorporating apparatus in accordance with an 
15 embodiment of the present inventions- 
Figures 2 through lie show samples of video 
display screens showing information presented during 
various stages of preparation of a survey document and 
answer document (response document] , such as may be 
20 presented by a display means of a processing apparatus in 
accordance with an embodiment of the present invention; 

Figure 12 illustrates a number of displays which 
may be presented by a display means of an apparatus in 
accordance with an embodiment of the present invention, 
25 illustrating operation of a collation means in accordance 
with an embodiment of the present invention; 

Figure 13 is a functional diagram of operation 
of an embodiment of the present invention; 

Figure 14 is a schematic representation of a 
30 database document which may be prepared in accordance 
with an embodiment of the present invention; 

Figure 15 is an illustration showing the various 
menu options available to a Survey Author in accordance 
with a preferred embodiment of the present invention; and 
35 Figure 16 graphically illustrates available 

setting options for the structure of the survey document 
of the preferred embodiment, and their operation. 

The following terminology is used 
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interchangeably in this document for specifying the • same 
thing. 

Response document « answer document. 
Author ° local user. 
5 Respondent or respondent user o remote user. 

Survey authoring means survey document 

preparation means. 

Local processing apparatus c processing 
apparatus including survey authoring means. 
10 Remote processing apparatus « respondent users 

processing apparatus or computer. 
Response document - answer document. 
Responses « answers. 

In figure 1, reference numeral 1 illustrates a 

15 local processing apparatus (a processing apparatus 
including the survey document preparation means) in the 
form of a personal computer (PC) , comprising a data 
processing means 2, an input means 3, 4, comprising a 
keyboard 3 and* mouse 4, and a video display unit 5. The 

20 local processing means 1 is connected by a communications 
system 6 to a plurality of remote processing apparatus (a 
respondent users processing apparatus) , each indicated by 
blocks 7 through 12. It will be appreciated that the 
local processing apparatus 1 may be connected to any 

25 number of remote processing apparatus by any type of 
communication system €. Blocks 7 through 12 are given as 
examples only. Note that the communications system 6 is 
an illustration only. Preferably, communications is via 
E-Mail (electronic mail) . E-Mail can employ telephones, 

30 satellites, optical fibres, etc. All that is required 
for a user to be connected to E-Mail is that he have an 
E-Mail address. The E-Mail user may log onto any 
computer terminal and receive mail. 

The local processing apparatus 1 includes a 

35 survey document preparation means to enable preparation 
of a survey document containing at least one question and 
preparation of a dato^Dase document having at least one 
database answer field for receiving answers to the at 
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least one question, and a collation means £or monitoring 
incoming E-Mail to identify response documents produced 
from processing of a survey document, to locate the 
datctbase relating to the particular survey, and to 
5 process the response document to load the at least one 
database answer field with the answer. 

Each of the remote processing apparatus are 
programmed with respondent control means to enable a 
respondent user to process a received survey document and 
10 produce an answer document (response document) from the 
processing, including responses (answers) formulated from 
data input by the user of the remote processing 
apparatus . 

In a preferred embodiment, the survey document 
15 ("survey") can be prepared and launched using windows™ 
with access to mail. To prepare the survey document, in 
a preferred embodiment a Survey Authoring (SA) module is 
utilised. The following is a description of preparation 
of a survey document using a Survey Authoring module in 
20 accordance with an embodiment of the present invention. 
Throughout the description representations of examples of 
video display unit screen displays produced by this 
embodiment of the present invention will be referred to, 
as in figures 2 through 11, to illustrate operation of 
25 the invention. 

After launching the Survey Author Module from 
Window Program Manager the user of the local processing 
apparatus (Item l. Figure 1.), the author ("local user"), 
will see the Survey Author Module screen featuring a Menu 
30 Bar and Tool Bar. Fig 4. Also, on launching, the Survey 
Author Module automatically creates a new survey 
document. In order to continue authoring this new survey 
document the author (local user) will need to create the 
first question. To do this he will choose the 
35 QUESTION/NEW QUESTION menu option (Figure 5) . The author 
(local user) will now be presented with the first blank 
question box (a frame section on the screen) (Figure 2) . 
This question box contains the standard NEXT and PREVIOUS 
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buttons as well as an area for question text. 

As the new question box appears, menu options 
for a range of question types for the author (local user) 
to choose from are enabled by the menu system. These 
5 types are: 

Option Button - With a series of Option Buttons 
the software will accept only one selection by the 
eventual respondent (remote user) . It is like a 
multiple choice question. The author (local user) 
10 will need to make this menu selection for each 

option button he requires in the current question 
box. 

Check Box - A check box enables the eventual 

respondent (remote user) to enter a "check" (a cross 
15 "X" mark signifying a yes or true status) in each 

check box placed in the question box by the Survey 
Author (local user) • 

Numerie Field - Same as Check Box except that 
the respondent (remote user) will enter numbers 

20 instead of ''checks". 

Text Field - Same as numeric field except 

that the respondent (remote user) will enter any 
alpha numeric characters rather than numbers. 
Option Buttons Grid - Grids in general are the 

25 same as the first three possible question types 

mentioned above. The difference is that they are 
arranged in a grid format. Therefore the author 
(local user) needs to specify the number of items 
and the arrangement of those items within the 

30 question box. For example: he may specify 12 

buttons and an arrangement of 3x4, 4x3, 2x6 or 6x2. 
Check Box Grid - The same as the Option 

Buttons Grid except that it behaves like a series of 
Check Boxes. 

35 An example of a Grid Check box is given in Figure 6 . 

Nuneric Field Grid - The same as the Option 
Buttons Grid except that it behaves like a series of 
Numeric Fields. 
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The question format may Include any combination of the 
above « e.g., a combination of an option buttons grid and 
a check box grid. 

Figures lla through lib illustrate, 
5 respectively, means which show dialogue boxes for: 

1. one option button properties (Fig lib) for 
specifying properties of option buttons. 

2. Numeric field properties, for specifying 
properties for a numeric field (Fig lie) . 

10 3. A text field properties dialogue box for 

specifying properties for a text field 
(Fig lid) . 

4. A label properties dialogue box (Fig lie) 
for specifying "label" for a text field. 
15 Displays for option buttons grid, check box grid 

and numeric field grid are not shown. The requirements 
for such a display, however, are apparent from the 
previous and following description on how the display 
looks is generally a matter for taste of the software 
20 engineer and the requirements of the system interface. 

To construct the survey document, the survey 
author will need to specify the following: 

a) . Question title (optional) ; 

b) . Question text; 

25 c) . Option, check, numeric or alpha label text 

or any combination thereof; 

d) . Where to GO TO after this question 

(optional) . This would be inserted where 
the author wishes to link the question to 
30 another - see later ; 

e) . Alter any database column names 

(optional) ; 

f ) , Select or alter default on selected 

database field values (optional) ; and 
35 g) . Select or alter default on never seen 

field values (optional) . 
The author (local user) may specify any one of 
the above types of question. Lets say the author (local 
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user) wishes to use three "Option Buttons" because he 
wants to give the respondents (remote users) three 
possible options to choose from for a specified question. 
To do this the author (local user) could use their mouse 
5 (Item 4. Figure 1.) to select ITEM/OPTION BUTTON from 
(see "ITEM" menu. Figure 15) the menu bar. They urould 
need to do this twice. The first click will cause 
display of two option buttons. The second will cause 
display of a third option button. Alternatively the 
10 author (local user) could use their mouse to click twice 
on a ""Option Button" Icon on the Tool Bar. Once the 
author (local user) has finished one of these two actions 
the frame work of his first question is complete. 

This first question contains three main features 
15 (see Fig. 7) : 

1. Two buttons at the bottom of the screen marked 

"Next* and "Previous". 
2- Three equally spaced ••Option Buttons" with 
"Option Button Text 01", "Option Button Text 
20 02", "Option Button Text 03" printed next to 

them. 

3. A "Question Text" area towards the top of the 
dialogue box. 

The author (local user) is now required to edit 
25 the variables for this question box. To do this the 
author (local user) double clicks on any clear space 
within the question box. The Question Properties 
dialogue box will appear on the screen containing the 
following variables 
30 Question Text - This is the area that the 

author (local user) enters the question that he wants the 
respondents (remote users) to answer. To enter the 

"Option Button Text 01", "Option Button Text 
02", "Option Button Text 03" printed next to them. 
35 3. A "Question Text" area towards the top of the 

dialogue box. 

The author (local user) is now required to edit 
the variables for this question box. To do this the 
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author (local user) double clicks on any clear space 
within the question box. The Question Properties 
dialogue box (Pigs, llf and llg) will appear on the 
screen containing the following variables 
5 Question Text - This is the area that the 

author (local user) enters the question that he wants the 
respondents (remote users) to answer. To enter the 
question text the author (local user) needs to select 
with his mouse the words "Question Text" and then over 
10 type it with the new text. 

In this example the author (local user) wishes 
to obtain information from respondents (remote users) as 
to what leave they will be taking between May and July. 
The respondents (remote users) may all belong to the same 
15 company, for example, and the author (local user) wishes 
to plan company leave. The author (local user) enters 
the following question text : 

"Will you be taking leave from work between 1 May 94 
and 1 July 94?". 
20 Question Title - These titles are used as 

reference to their particular question. These 
references are used in (question selection menus, for 
selecting a current question to edit, and to 
nominate the branching of the questions (see later) . 
25 The system generates a default "Question No. 001" 

where the number part increments for each new 
question box. The titles may be edited but must be 
a unique reference within the survey document. In 
this example the author (local user) will change the 
30 Question Title to •LEAVE*'. 

The next step is to enter the relevant defaults 
for each of the three Option Buttons. To do this the 
author (local user) simply points at the first Option 
Button and double clicks with the mouse. The Option 
35 Button Properties dialogue box will appear. The main 
features of this dialogue box are: 

Option Text - This * is where the 

author (local user) will specify the text that 
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corresponds to that particular option. In- the 
question text the author (local user) asked about 
staff leave. He should now nominate the text for 
one of the options that the respondents (remote 
5 users) will be able to choose from. 

For Example: "Yes I will be taking leave during this 
period" . 

Database Field Name - This is the name of the 
column in the database to be prepared in accordance 

10 with this embodiment, that will contain answers to 

this question (the "database column heading") . The 
column heading may be prepared on the basis of data 
input by the author (local user) specifically for 
the column heading. In a preferred embodiment, a 

15 default column heading is inserted should the author 

(local user) not wish to input his own. More 
preferably, the default may be automatically 
prepared from components of the question text. This 
is particularly useful for the check box grid and 

20 numeric field grid type questions. Each check box 

grid or numeric field grid comprises a matrix of 
rows and columns, each row and column having a 
header title. Each point (cell) designated by the 
row and column in the grid matrix is a point where a 

25 respondent (remote user) will enter, selectively, an 

answer. In a preferred embodiment, a database 
column heading is automatically prepared from 
components of the row and/or column heading of the 
check box grid or numeric field grid matrix. In this 

30 example this field need only be filled in once as 

there is only the one Database Column associated 
with this question. The author (local user) will 
name the Database Column Heading as ''LEAVE**. The 
default will be the same as the question title. 

35 Branehed-To Question - This is where the 

author (local user) enters the next question that 
this option would take the respondent (remote user) 
to if the option were selected. Obviously the 
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author (local U8er)ie not able to nominate the' next 
question at this point because he is currently 
working on the first and only question. However, 
the author (local user) can nominate one of three 
5 special branching destinations. Any of these 

destinations, {FINISH}, {NEXT} and {NONE} can be 
used for just this particular question option, or 
they can be set as the default for this survey 
document or the entire system. Specifying {FINISH} 
10 will mean that the respondent (remote user) will go 

straight to the Finish Question Box at the end of 
the survey document. 

The {next} destination will automatically branch 
to the next question the author (local user) generates. 
15 The {none} destination will become a 

"cul-de-sac". In other words the question will lead 
nowhere. When testing the survey document (see later) it 
will be indicated to the author (local user) that a 
question exists which is an orphan or a cul-de-sac and 
20 the author (local user) will be able to make appropriate 
corrections. In this example the Option Button text says 
"Yes I will be taking leave during this period", and the 
author (local user) may therefore require additional 
information so he would want this option to branch to 
25 another question. In this example there is only one 
other question so the author (local user) can select 
{NEXT} even though the question has not been generated 
yet. (In an alternative embodiment branching control 
instructions may be included - see later) . 
30 On Selection Database Field Value - This is 

where the author (local user) specifies the entry he 
would like to appear in the database answer field if 
the respondent (remote user) were to select this 
option. In this example the Option Button text says 
35 "Yes I will be taking leave during this period", so 

an appropriate On Selection Database Field Value 
would be "Y" or "YES" . 

In some cases, the on selection database field 
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value may be chosen automatically. In particular, where 
the question is in the form of a option buttons grid, 
having a plurality of rows and columns « each row and 
column having a heading and specifying a plurality of 
5 points (cells) in the grid for selection by a respondent 
(remote user) , a single column heading may be available 
in the database and the field value entered in response 
to answering of the question by a respondent (remote 
user) may be automatically selected from components of 
10 the row and/or coliunn heading for the particular option 
selected. It will be appreciated that selected field 
values could be automatically selected for other types of 
question, as well as option buttons grid. 

Never Seen Database Field Value If the 

15 question has not been presented to the respondent 

(local user) due to the fact that their answers have 
taken them do%m another route the never seen 
database value will appear in the database answer 
field. 

20 For Example: There may be a series of questions 

within the survey document that apply to one 
particular group and not another ie. Males - 
Females, Wage earner - Salary earner etc. 

The database field value defaults to "BY PASSED'* 
25 or "NOT ACCESSED" or the like. This can be edited here 
on each question, or can be permanently changed for this 
and all future survey documents by using the TOOL/OPTIONS 
menu. In this example the author (local user) will not 
change the Never Seen Database Field value. Now the 
30 author (local user) presses Enter or clicks OK. 

This has now completed the process of editing 
the variables for the first option of the first question. 
If the author (local user) presses Enter or clicks OK, he 
will now see the question option text appear in the 
35 question box. 

To complete the range of options available to 
the respondents (remote users) the author (local user) 
must repeat the above mentioned process on the next two 
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10 



15 



20 



25 



30 



options. However, as this is an option button based' 
question there will be only one database colunm and 
therefore there is no need for the author (local user) to 
nominate either the Database Column Heading or the Never 
Seen Database Field Value again. 

Lets assume that your three options are as 

follows : 



Option Button Tf 



' — 

1 Yes I will be taking leave 
I during this period. 

No I will not be taking 
leave during this period. 

, I am not sure at this 
I time. 



On Selection 
Database Field 
Entry 



Branching to 



N 



M 




See Figure 8 for a screen display of the 
question text and allowable answers. 

The author (local user) then saves the work he 
has done so far by selecting the FILE/SAVE menu option. 
The survey document may be given a unique and descriptive 
name. Such as HOLIDAY. SVM. 

•The author (local user) can now go ahead and 
create the final question in the survey document. To 
start a new question the author (local user) must select 
the QUESTION/NEW QUESTION menu option. This will present 
the author (local user) with a new question box 
containing, as before, the "NEXT" and PREVIOUS buttons as 
well as the Question Text area. The author (local user) 
can now proceed as per the first question but using the 
new set of variables. 

Lets assume that the final question is an 
option-type question and the parameters are as follows: 
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Variable 


Question Text 


Where will you be 

hoi ida vino 


R Question Title 


Destination 


Database Column Heading 


Destination 


Never Seen Database Field Value 


BY PASSED 


Option One: Option Text 


New South Wales 


Option One: Branching To: 


(FINISH) 


Option One: On Selection 
Database Field Value 


NSW 


Option Two: Option Text 


Australia, but not 
NSW 


Option Two: Branching To: 


{finish} 


Option Two: On Selection 
Database Field Value 


AUST 


Option Three: Option Text 


Overseas 


Option Three: Branching To: 


{FINISH} 


I Option Three: On Selection 

II Database Field Value 


OS 


Now that the second and 


final question of this 


brief survey document has been completed the author 


(local user) can take a look at the linking o£ options 



from question one (LEAVE) to question two (DESTINATION) 
or FINISH (end of survey document) . 

Earlier the Branched*>To Question field was 
mentioned and the author (local user) used the {NEXT} and 

25 {FINISH} options because he could not nominate the 

""Question Title** of the next question at that point. Now 
that the next question has a title, "Destination**, the 
"Branching To" field in the previous question that 
contained the {NEXT} option will automatically change to 

30 read (DESTINATION) . 

So in summary, the author (local user) has asked 
a question relating to leave being talcen and another 
relating to where the respondent (remote user) will be 
taking this leave. Now clearly if the respondent (remote 

35 user) has answered either option two or three (No and Not 
sure) to the first (juestion (LEAVE) there is no need for 
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them to answer the second question (DESTINATION) and' 
therefore they should go straight on to (FINISH) . Option 
one (Yes I will be taking leave during this period) of 
question one (LEAVE) should lead to question two 
5 (DESTINATION) . As the second question is also the last 
the author (local user) may choose settings of {FINISH} 
as all options will need to lead to the end of the survey 
document . 

Although in this example the author (local user) 
10 has chosen the {NEXT} option to automatically handle his 
linking it can be done manually using the following 
process . 

The first thing to do is to get the first 
question (Leave) back on the screen* This is done by 
15 selecting the QUESTION/(X)TO QUESTION menu, and the 
choosing of "LEAVE" of the list (Fig. 9). 

Question one (LEAVE) is now displayed on the 
screen. Double clicking on the first option (Yes I 
will,...) will display the option button properties 
20 dialogue box. From the list displayed in the Branched-To 
Question section select the second questions title 
"DESTINATION" and press Enter or click OK. 

The final step before testing is to nominate 
which question is the first question to be presented to 
25 the respondent (remote user) . This is done by selecting 
the QUESTION/SET FIRST QUESTION menu and nominating the 
Question Title of the appropriate question. 

The first test that the author (local user) 
should perform is the SCAN TEST. This is accessed 
30 through the T0OLS/S(»N menu option (Figure 15) . 

On selecting SCAN TEST the arrangement scans 
through the survey document and searches for any errors 
in the question structure. This is particularly 
important for complex survey documents which incorporate 
35 a number of branched-to questions. SCAN TEST generates a 
report of "orphans" and "cul-de-sac" ie., questions which 
no other questions lead to and questions which do not 
lead to anything. The arrangement is aware that there is 
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a single question which will not have a preceding 
question (the question selected as the first cjuestion in 
the survey document) and a single question which will not 
have a succeeding question (the last question in the 
5 survey document) . It may test all the other questions 

simply to determine for orphans or cul-de-sacs. Once any 
existing orphans or cul-de-sacs have been identified the 
author (local user) can access them to correct them. 

In addition to orphans or cul-de-sacs SCAN TEST 

10 also identifies any Cross Linked Questions (A child 

question that branches to any preceding question) and 
Duplicate Database Field Names. It will also test for 
illegal names (e.g. over eight characters for DOS based 
database) and missing names. 

15 In one embodiment, an entire list of the items 

appears on the authors (local users) screen. Cliclcing on 
one item immediately talces the author (local user) to 
that item. By "item" is meant any item which may be 
determined by the local user in preparing the Survey 

20 Document, e.g., Goto*s, not accessed, branching-to 

questions, DatabaseFieldName, etc. The listing will not 
include information such as question text (although the 
question title is listed) and the like which do not 
effect the mechanical structure of the Survey Document 

25 (e.g., the pathway through the Survey Document) . It is a 
mandatory requirement, however, that the author enter 
Question Text. While this will not affect the mechanical 
operation of the document (the way it runs on the 
respondents processor) , if no Question Text is provided, 

30 the respondent user will view a blanJc question (i.e., no 
question) . A test for question text is therefore 
importauit and is included. There may be other mandatory 
items such as question labels. 

The listing enables the author to briefly checlc 

35 that the document structure reads as desired. Any items 
identified by the scan test as being in error are 
preferably highlighted in the listing so that the user 
can cliclc on them and take the appropriate action to 
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correct the error. An embodiment ia envisaged where all 
variables in the Survey Document which could be effected 
by the author or system configuration are listed. 

Once the SCAN TEST has been completed without 
5 error the author (local user) can be confident that the 
mechanics of their survey document are in order. 

The Respondent Test is accessed either via the 
TOOLS/TEST FROM TOP (Figure 15) or by a simple click on a 
"Test" icon on the tool bar. 
10 Activating Respondent Test will take the author 

(local user) through the survey document as if he where a 
respondent (remote user) . 

A further test is TOOLS/TEST FROM CURRENT 
(figure 16) this allows the local user the option of 
15 testing the Survey Document from any particular question 
he is currently displaying. 

Prior to sending the survey document the author 
(local user) determines the electronic mail address the 
response documents are sent to. FILE/SET REPLY ADDR 
20 (Figure 15) and then nominates the return address. 

Once the author (local user) is satisfied that 
the survey document works and that the response will be 
' going to the correct mail address he may send it to his 
target audience. 
25 To do this he selects the FILE/SEND SURVEY 

(Figure 16) menu option (Fig- 10) . 

The Survey Author Module assumes that the author 
(local user) will be sending the survey document that is 
currently loaded. 
30 It will present a dialogue box listing of all 

the respondents (remote users) and groups of 
respondents (remote users) that the author (local user) 
could mail to. The survey author may also mail to the 
respondents of previous surveys. A listing of the 
35 respondents of previous surveys is kept. The dialogue 
and box will also list all the previous surveys so that 
the author may click on a selected previous survey to 
send to remote users who filed responses for that survey. 
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Methods nvay also be used to select sub groups within the 
targeted database. The author (local user) will make his 
selection and press Enter or click OK. Another dialogue 
box will appear enabling the author (local user) to 
5 attach a message to the survey document. For exaiiQ>le the 
author (local user) could use this to introduce the 
survey document to the respondents (remote users) and 
explain the benefits to them or the organisation of 
responding to it quickly. Once the author (local user) 

10 is satisfied that everything is OK he can press Enter or 
click OK. The small survey document will then be on its 
way to its target audience. At the same time (in the 
preferred embodiment, just prior to transmission) the 
apparatus will automatically create the database in 

15 preparation for the responses. Also, at the point that 

the local user selects the FILE/SEND survey menu from the 
Pile menu they are offered a dialogue box requesting them 
to name the SVQ (survey document to be sent out) file 
that is about to be sent out. The default name is that 

20 of the SVM (the survey document master - see later) . 

Once the local user has either selected a new name for 
the SVQ or accepted the default name the local user will 
be offered another dialogue box asking for them to select 
the database type that they would like to create for this 

25 survey to be collated into. At this point the local user 
will ask for either a database name and/or table name. 
The default will be the SVQ name. However « the local 
user can change it. 

The database can be fully populated if the 

30 author is mailing the survey to a list of )cnown users. 
However, there is the option for the database not to be 
populated if their survey is sent to a group, for 
example, or put on a bulletin board. In the present 
example, the database is fully populated. 

35 See figure 14 for a diagrammatic representation 

of the database. The database is comprised of three 
columns and N -i- l respondent (remote user) rows, where N 
is the number of respondents (remote users) (-•- 1 is the 
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row containing the column headings) . The three columns 
include two columns for the two respective questions, and 
a column which contains respondent (remote user) ID. 
Note that a number of fields may be necessary for a users 
5 mail address. The columns and rows intersect in matrix 
form to provide database answer fields in the form of 
cells, for the entry of the appropriate field value as 
amswer documents are processed. 

Each remote processing apparatus may be 
10 configured with a "Survey User Module*' or recipient 
module (response module) to enable preparation of an 
answer document in answer to the survey document. The 
Survey User Module will be installed either on the server 
that the respondent (remote user or recipient) is 
15 attached to in the networ)c, or on the respondents (remote 
users ) machine . 

Alternatively, the recipient module may be 
transmitted with the survey document, so that a 
respondents users computer need not even be configured to 
20 be able to process the survey document. Instead, the 
recipient module transmitted with the survey document 
will configure the respondent users computer. 

The respondent (remote user) will generally 
access the survey document through their normal 
25 electronic mail procedure. Where the respondent (remote 
user) is not connected to electronic mail, he may receive 
the survey document by another communications medium, eg. 
by normal mail, or by any other means. They will read 
the mail that has accompanied the survey document and 
30 then use their mouse to select and launch the survey 

document. On their screen will appear the question one 
(LEAVE) dialogue. They will use their mouse to select 
the option that applies to them. They will then cliclc on 
next. Depending on their selection either the (FINISH) 
35 or the (DESTINATION) dialogue box will appear. Once they 
have answered all the questions the (FINISH) screen 
(Figure 11) will appear thanking them for the involvement 
in the survey. Once they press Enter or click Finish all 
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of their answers will be transnitced back to the Survey 
Collator Module automatically. 



the Survey Collator Module is arranged to monitor 
5 incoming transmissions via electronic mail other means, 
even manual entry) to identify answer documents for the 
particular survey. The "Survey Collator Module" is 
applied to gather all the incoming responses and load 
them in the database. In the preferred embodiment, as 
10 described below with reference to figure 12, the Survey 
Collator Module has a number of functions, operation of 
which may be dictated by the collator (local user) . 



entered on a different processing apparatus to the 
15 processing apparatus which the author (local user) used 

to prepare the survey document. This arrangement will be 
particularly useful where the author (local user) makes 
heavy use of a particular computer and, although he may 
wish to prepare the survey document using that computer, 
20 he does not wish machine time to be taken up with 
collation of answer documents. He can therefore 
designate another machine to receive and collate the 
answer documents. 



The local processing apparatus, in particular 



Note that the Survey Collator Module may be 



35 



30 



25 



Survey Collator Module - As 

previously explained this module of the application 
gathers all the incoming responses and puts them in 
a database ready for analysis. When this module is 
first launched the collator (local user) must 
select the SURVEY/ PROCESS menu. The collation 
process is automatic. An options menu is provided 
which enables the local user to select whether a 
particular survey should be "activated", "suspended" 
or "terminated". When a survey is "activated" the 
collator will automatically collate all response 
documents relating to that survey. When a survey is 
"suspended" (dl in Fig 12) , the collator will 
receive an identify response documents relating to 
the survey but will not process them. It will 
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merely store them. When a survey is "terminated** 
the collator will identify all response documents 
relating to that survey and delete them upon 
arrival . 

5 The Survey/ Process menu will now attempt to 

logon and start the collation process. On loading the 
collator module it will not start the collation process 
until the Survey/ Process menu has been selected. The way 
that the collator gets to know about the surveys is when 

10 the first response document comes in. When this happens 
the collator puts its name up on the screen along with 
information relating to the last date and time it 
received an entry and the total number of entries it has 
received for that survey to date. The collator will 

15 continue to collate the "activated" survey entries until 
the local user "suspends" the process. The local user 
can also decide to "terminate" the survey, in which case 
all incoming responses will be deleted upon arrival (see 
later for description of "activated, suspended, and 

20 terminated"). All surveys will list on the screen 

regardless of which of the three states they are in. The 
local user could decide to delete a survey from the list. 
However, if an answer document comes in it will attempt 
to restart the collation process. 

25 Figure 12 (a) illustrates the main Survey 

Collator Module screen of this embodiment. The Survey 
Collator Module can handle a plurality of different 
surveys, exemplified in figure 12(a) by "survey 1" and 
"survey 2" under "survey name". 

30 Once the collator (local user) has done this 

the Survey Collator Module will automatically start the 
electronic mail if it is not already running and then 
start to scan for incoming responses. 

On the screen the collator (local user) will 
35 notice that the Survey Collator Module tells him how many 
responses it has received and what percentage that amount 
represents of the total the survey document was sent to 
("Total #", "« Read", "% Process"). The "total" and 
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"percentage process" will only appear when the survey has 
been sent to a known list of respondents and a 
pre-populated database option has been chosen. Where the 
database is unpopulated, obviously the collator will not 
S know how many respondents will be required to fill the 
database . 

If after a few days the collator (local user) 
notices that the responses have slowed down to a trickle 
he may like to send all those who have not yet responded 

10 a quick reminder. This can be done automatically by 
selecting the SURVEY/REMIND menu option (Pig. 12(b)). 
Having done this the collator (local user) will be asked 
to type a brief reminder message. Once the collator 
(local user) presses Enter or Clicks OK the Survey 

15 Collator Module will interrogate the nominated survey 
database and send the mail to all the non- respondents. 
This should prompt a few more to respond to the survey. 
However, if in a few more days the collator (local user) 
still has not received all the responses he may select 

20 SURVEY/RE -SEND menu (Fig. 12(c)). This works the same 

way as REMIND but along with a message from the collator 
(local user) it will retransmit the survey document. 

Once the collator (local user) is happy with the 
number or percentage of the responses received he can 

25 de-activate the survey document by selecting the 

SURVEY/TERMINATE menu option (Pig. 12(d) and 12(e)). 
This means that Survey Collator Module will discard all 
responses for this survey from now on. The database will 
contain audience responses for each user. If the 

30 respondent (remote user) does not respond this may be 
indicated in an extra database column (the "respond 
column") • 

There is also the option of gathering various 
information available automatically on the E-Mail system. 
5 For example, postcodes, telephone numbers, etc. Various 
database columns would be prepared to receive this 
automatically gathered information, which would not be 
part of the survey document received by the remote user. 
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Further options include date/time stamping depending on 
the time the answer document was received and/or the 
ability to log whether this is a reply to an original 
survey or a reply to a reminder or a reply to a re -sent 
5 survey. Appropriate database columns would be required. 

Figure 12(g) illustrates "Options" available 
with the survey collator. 

Figure 13 shows a functional diagram of the 
survey system. The functional diagram shows in brief the 

10 steps discussed above of operation of the apparatus and 
method in accordance with the embodiment discussed above. 
At 100 the author creates a survey with a survey name 101 
and mails it out to a remote user 105. Further, just 
prior to mailing of the survey, the database is created 

15 at 102, the questionnaire is prepared at 103, and the 
questionnaire is mailed to the Collator at 104. 

At the remote user end of the system, at 106 the 
user reads and processes the survey and creates an answer 
document at 107 and sends 108 by mail back to the 

20 collator. 

At the local user end, at 109 the collator reads 
the questionnaire and notes the existence of the survey 
in its register. Later at 110 the collator reads the 
answer document and updates the database at 111 with the 
25 answer. 

In operation, when the survey document has been 
completed prior to transmission it is a master. The 
document sent out is a subset of the survey master, knovm 
as the SVQ. The SVQ is saved for subsequent 

30 re -transmission, e.g., if reminders are required. At the 
point that the local user selects the FILE/SEND survey 
MENU OPTION from the file menu they are offered a 
dialogue box requesting them to name the SVQ file that is 
about to be sent out. The default name is that of the 

35 SVM. Once the local user has either selected a new name 
for the SVQ or accepted the default name the local user 
will be offered another dialogue box asking for them 
select the database type that they would like to create 
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for this survey to be collated into (see above) . As • 
discussed above, at this point the local user will be 
asked for either a database name and/or table name. The 
default will be whatever the SVQ was named, although the 
local user can change it. The safeguard here is that the 
local user will not be able to select an existing 
database name or table name within an existing database. 

Note that the SVQ is also preferably saved in 
collator, as reminders will most probably be sent from 
them. 

One advantageous feature of a preferred 
embodiment of the invention, as briefly discussed above 
relates to the naming of the database column headings 
when a question and allowable answer utilise a numeric 
field grid or check box grid. For example, referring to 
figure 6, which illustrates a check box grid, it will be 
appreciated that there are 16 possible answers (check box 
cells) to this question. If the remote user has more 
than one car, he may check more than one cell. Sixteen 
database columns are therefore required. Manually 
choosing a name for each of these database columns would 
be laborious. To overcome this problem, the apparatus 
and method of a preferred embodiment of the present 
invention automatically designate database column 
headings which are formed from components of the column 
and row grid headings. For example, the name for the 
database column heading corresponding to the top left 
hand comer check box cell may automatically be set at 
"sedan 4". Similarly with the rest of the check box 
cells. This naming technique can also be applied for a 
numeric field grid. The column heading may be formed 
from combining the entire column and row headings of the 
grid, as above, by combining components of both of them, 
or by using the column or row heading only or a component 
thereof . 

For option button grids, where only one option 
is allowed to be chosen, in a preferred embodiment of the 
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invention, as discussed briefly above, it is only 
necessary for the database to contain one database 
column, no matter the number of possible answers. In 
this case, the database field value to be entered in the 
5 database column in dependence on the remote users answer 
is chosen from components of the column and row headings 
of the grid. With the option buttons grid therefore, the 
actual field value to be entered is named from the 
headings of the rows and colximns of the grid box cell 
10 selected. As discussed previously, option button girds 
may include a series of sub-groups requiring the remote 
user to select a single option item in each of the 
sub-groups. In this case, as many columns in the 
database will be required as their are sub-groups. 
15 An advantageous feature of a preferred 

embodiment of the invention allows the database to be 
fully loaded prior to the survey document being sent out, 
in order to test whether the apparatus can accommodate 
the fully loaded database. 
20 In the embodiment described above, when the 

remote user receives the survey document (SVQ) and 
processes it on his apparatus to produce an answer 
document (SVR) , the SVR is sent back and the original 
mail message and the SVQ are deleted or the remote user 
25 is told to delete, so that they cannot be used again by 
the remote user. A further option exists for the Survey 
Author (local user) however, to provide an instruction 
that tells the remote users net to delete the SVQ when 
the answer document is sent back. This enables a 
30 requirement for regular information (weekly, monthly, 
quarterly) to be met by the remote user by simply 
re-r\anning the SVQ on a regular basis. If such an option 
is utilised, the databases prepared to include a "time 
received" database column to indicate a time at which the 
35 particular answer document is received from the 
particular user. 

The following is a description of the structure 
of a software implementation of the preferred embodiment 
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of the present invention, a working example of which *ha6 
been explained above generally from the point of view of 
user operation of the embodiment. 

Software code has not been listed. The 
5 following description of the software modules and the 
various "features" they are required to execute will be 
sufficient, together with the following descriptions of 
the various documents (survey master document, survey 
question document and survey response document) , and the 

10 previous description of the fimctions of the system, to 
enable a person skilled in the art to construct software. 

This description does not describe the specifics 
of the user interface, as, except where certain 
operational rules are enforced, the specifics are 

15 fundamentally irrelevant to the description of the 

current embodiment. The operational rules will be covered 
at the end of this description. 

The computer language used within this 
description when detailing structures is generic, but a 

20 person skilled in the art will easily be able to convert 
these details to an appropriate computer language. 
Overview 

The preferred embodiment is conposed of three 
separate but related software modules : 
25 * Survey Authoring Module - herein knovm as the Author 

(local user) 

* Survey Recipient Module - herein known as the 
Recipient (remote user) 

* Survey Collating Module - herein known as the 
30 Collator (local user) 

In the current embodiment all three modules are 
designed as Microsoft Windows applications, having been 
vnritten and complied in Microsoft Visual C^f-t- using 
Microsoft's MFC Class Library. All three modules 
35 interface to Microsoft E-Mail through the MAPI interface. 
Both the Author and the Collator modules access databases 
through Microsoft ODBC interface, allowing the system to 
work with almost all available databases. 
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Standard programming techniques have been ueed 
ae much as possible to allow portability to other systems 
that support MFC, 

There are three areas where slightly 
5 non-standard techniques have been used: 

1. The presentation of the dialogue boxes in the 
Respondent module (and equally their presentation in test 
mode within the Author module) utilises a Windows feature 
of being able to present a dialogue box from a template 

10 in memory instead of the usual method of presentation 

from a static resource. This allows dynamic control of 
the appearance and content of the dialogue boxes from 
information stored in the questionnaire (SVQ) . 

2. At the point when the survey questionnaire is to 
15 be mailed to the remote users the Respondent module 

(Response Exe) is pre-pended to the actual questionnaire 
document (SVQ), given the 'file -name' of the survey 
master document (SVM) and the extension 'Exe'. 

It should be noted that the SVQ is a C++ 

20 'object', and to achieve data persistence its MFC 
archiving methods are used both to write it at the 
Author, and to reload it at Respondent. 

When the remote user runs the composite file, 
the Respondent module start-up-code offsets the file 

25 pointer in the MFC standard archive read method to point 
to the SVQ section of itself. It then loads the data to 
're- instantiate' itself, processes the data through the 
normal SVQ methods and presents the questions to the 
user. The composite file transmitted to the Respondents 

30 operates as a true 'object' with encapsulated SVQ data. 

(Note that an •object'/ as will be understood by 
a skilled person, is a collection of executable methods 
that are specific to the encapsulated data types and 
structure (an 'instance' of which is held within the 

35 object) , and (generally) those methods are the only way 
for external agents (people or processes) to operate on 
that data) . 

3. Following on from (2) above, the final size of 
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the composite file is largely determined by the number of 
executable SVQ methods which are mailed with the SVQ 
data. To increase efficiency through the E-Mail system 
the size of the composite file should be as small as 
5 possible. By using conditional compiles on the SVQ 

object, a common minimal 'set* is used by the Respondent 
module, while the full 'set* is available to the Author 
module . 

The common minimal set will be a matter of 
10 choice of the skilled person, who will be able to 

establish the minimal set of methods required to run the 
SVQ by the respondent module. 
The Author ModulA 

The main functions of the Author module are the 
15 design of the questionnaire, preparation of an 

appropriate database, and the transmission of the 

questionnaire to the remote users. 

All Author functionality is derived from the 

Survey Master Document (SVM) methods. 
20 Note: the SVM contains the Survey Questionnaire 

Document (SVQ) inside itself so that all SVQ methods are 

available to the Author. Further the SVQ contains an 

array of 'Question-Box objects' inside itself so that all 

Question-Box methods are available to the Author. The 
25 data members for the SVM/SVQ/Question-Box 'objects' and 

the functionality of the more relevant methods are 

detailed below. 

The Menu structure, as will be realised form the 

preceding description, is based as closely as possible on 
30 Microsoft 'Office' products to achieve the highest degree 

of user interface compatibility with Microsoft standards 

and therefore facilitating ease of use. 

The user interface for the dialogue box editing 

used in the creation of the question boxes is preferably 
35 based on several Microsoft and Borland 'dialogue 

editors' . Other techniques could be used. 

One of the underpinning interface design 

criteria has been to shield the Author user from the need 
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to have any knowledge about databases. 

The Author module generates default database 
field names based on the Question names^ e.g., user 
question name as the field name. Users can change the 
5 database field names if they wish but there is no need to 
do so. 

The database field types required are, in this 
preferred embodiment, deliberately limited to Boolean 
(Logical), Text and Numeric. Except for 'Numeric* 

10 fields, the other types are automatically deduced by the 
Author module, and the user is shielded from the need to 
set the database field types. For 'Numeric' fields the 
database field types default to 'Integer' but the user 
may change them to 'Decimal' (assumed 2 places) if they 

15 wish. 

The database field length is automatically 
deduced for Boolean and Numeric fields, and a default 
calculation is performed for the length of Text fields 
based on the length of the field on the users 's screen 

20 (which may be set by the survey author, as discussed 
previously) . 

In the interests of making life easier for the 
user various 'features' are designed into the system for 
the preferred embodiment. 

25 For the Quenstion's goto directives the Author 

defaults to a system specific value of '{Next}'. When a 
new Question is added, the Author module automatically 
retro-fits the new Question's name into the previous 
Question's goto directives if they were set to '{Next}'. 

30 Equally if the user changes the names of a 

Question all other questions are scanned to see if any of 
the other Quenstion's goto directives point to the 
current Question, and if so, their goto directives are 
changed to reflect the new names. 

35 The scan test (part of the author module) tests 

for as wide a range of errors possible: 

1. 'Orphan' or 'Cul-de-sac' questions. 

2 . Question Box text which has not been 
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changed from the system default 'Question 
Text for Question No. 001*. 

3. Item (Option Buttons, Check Boxes, and 
Labels) text which has not changed from 

5 the system defaults ('Option Button Text 

01', 'Check Box Text 01', and 'Label 01" 
respectively) . 

4. Duplicate database field names. 

5. Any missing fields. 

10 The author module automatically checks for 

missing, or duplicate or illegal database table names at 
the point of creation of the survey database. 

A wide range of system defaults exist for the 
user to set the default size and position of the Question 

15 Box, default values for all the items, default values for 
the 'Never Seen Value • and the default goto directive. 

The author automatically generates the last 
Question ('{FINISH}') when a new survey document is 
created . 

20 When the user decides to mail out the survey to 

the remote users the following 8eG[uence occurs : 

1- The user is presented with a list of E-Mail 
users (via the MAPI mail interface) for the 
remote users (or groups of remote users) to be 
25 selected. 

2. The user is presented with a suitable 'Subject 
and Note' dialogue box to advise the remote 
users about the survey. 

3. The user is presented with a list of E-Mail 
0 users (via the MAPI mail interface) for the 

Collator E*Mail address to be selected. 

4. The user is presented with standard ODBC 
dialogues for the selection (or creation) of the 
Data Set Name (DSN) for the required database. 

5 5. This is followed by a dialogue box where the 

user is asked to enter the 'table name' for the 
survey (defaults to the name of the survey) . 
6. The table is created in the ODBC database. 
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7. The SVQ section of the SVM is written to disk. 

8. Respondent module (Response Exe) is pre-pended 
to the SVQ, given the 'file-name' of the Survey 
Master Document (SVM) and the extension 'Exe". 

5 9. The 'composite object' of Response Exe and the 

SVQ is mailed to the selected respondents (and 
to the Collator E-Mail address) via the E-Mail 
system. 
Thg Reanondent Module 

XO The composite file, containing both the Response 

Exe (the executable methods for the SVQ) and the SVQ 
'persistent data', appear as an executable file attached 
to the E-Mail message containing the 'Subject and Note* 
texts (mentioned in the Author module above) . When the 

15 user launches the attached executable its start-up-code 

offsets the file pointer in the MFC standard archive read 
method to point to the SVQ data section of itself. It 
then loads the data to 're- instantiate' itself, processes 
the data through the ' common minimal set ' of SVQ methods 

20 and presents the questions to the user. The answers are 
stored in the SVQ as the user wor)cs through the 
questionnaire. When the user finally exits the 
•{Finish}' terminating question, the answers are copied 
to the Survey Response Document (SVR) . 

25 As there may be hundreds (or thousands) of SVR 

documents arriving at the Collator's E-Mail address, the 
size of the SVR is extremely important. For this reason 
the SVR has been created separately from the SVQ. While 
the SVR*s data members are exact copies of the associated 

30 data members in the SVQ the number of members is reduced 
to the bare essentials - see below for a description of 
the SVR structure. 
Collator 

The Collator works with 3 document types: 
35 1. Its own 'survey register' document, which is a 

list of current surveys including relevant 
associated information - see below. 
2 . The Survey Questionnaire document (SVQ) . 
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3 . The Survey Response Document (SVR) . 

The Collator's main function is to read incoming 
survey response documents (SVR) and update (or add) the 
respondents answer information to the appropriate ODBC 
5 database . 

The Collators other functions are: 
1. To read incoming survey questionnaire documents 
(SVQ) and register the new survey in the 
Collator * s ' register * . 
10 2. To send reminders to entries in a pre -populated 

database that have not yet responded (i.e,, the 
Mail Received Date field is still set to the 
default) . 

3. To re-send the Survey Questionnaire Document 
15 (SVQ) to E-Mail users that request a resend, or 

to entries in a pre -populated database that have 
not yet responded (i.e., the Mail Received Date 
field is still set to default) . 
Outside of the methods available to Collator 
20 through the document •objects' that it is 'aware' of, the 
Collator is a straight forward and simple program. 

Upon starting the Collator reads the E-Mail 
message queue to ascertain if there are any relevant 
messages of it. 
25 If there are no relevant messages it goes to 

•sleep' for a period of time controlled through its user 
definable options (see Figure 12) . 

If there are messages to process then it sits in 
a loop reading and processing messages up to a number 
30 specified again in its user definable options (see Figure 
12), or until there are no more messages to process, 
where upon it will put itself to 'sleep' again. 

If it has been 'asleep', it will re-enter the 
loop as if it had just started. 
35 When it processes an SVR (assuming the 

associated survey has been registered) it will update the 
appropriate database and delete the E-Mail message 
containing the processed SVR. 
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When it processes an SVQ it will register the 
new survey in its 'register' and copy the SVQ to a user 
definable directoiry for safe keeping. The surveys are 
registered with a default status of • Active' but the user 
5 may choose to set that initial status to 'Suspended' to 
have manual control over when surveys are processed, 
ffffll^^^^ E>Mail Messages 

The Collator monitors the E-Mail in-tray- It 
searches for 2 types of E-Mail messages. 
10 1. The copy of the Survey Questionnaire Document 

(SVQ) sent by the Authoring module at 
questionnaire transmission time, and 
2. The Survey Response Documents (SVR) returned by 
the respondents (remote users) . 
15 Both these messages are coded with a signature 

so that they can be picked out from the normal E-Mail 
that may arrive. The signature indicates what types of 
message they are, but not which particular survey or 
database they belong to. Collator has to open the 
20 messages and read them to ascertain that specific 
information, 
r^llator Survey Status 

Collator maintains a 'register' where all the 
current and recent surveys that it is 'aware' of are 
25 listed. Each survey has an associated status as 
discussed previously: 

1. Active - the survey is being processed normally. 
The responses are being read, the database is 
being updated or added to and the read messages 

30 are being deleted once they have been 

successfully processed.' 

2. Suspended - the survey responses are ignored. 
Collator reads the message « ascertains that the 
survey is in a suspended state and advances to 

35 read the next E-Mail message. This state is set 

to temporarily isolate the database from the 
incoming E-Mail. This is useful for accessing 
the database before the survey is terminated. 
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for staged analysis or repair. A suspended- 
survey can either be re-activated or terminated, 
A survey may optionally be set to suspended the 
instant that it is registered. 
5 3. Terminated - the survey is concluded. Any 

E-Mail associated with this particular survey 
will be read to ascertain its identity and then 
deleted without any processing. 
Collator SurvftV ReaistratiQn 
10 Collator registration occurs as a result of 

receiving either the SVQ or an SVR E-Mail message for a 
survey that has not yet been 'registered'. The survey is 
immediately stored in Collator's internal register, and 
the status is either set to 'Active' or ''Suspended' 
15 depending on the user options that have been set. A user 
may choose to set the 'Suspended-on-registration' option 
if the user wishes to set the survey 'cut-off values 
before any of the responses are processed. 

The associated database and the number of 
20 responses received is also stored in the register on a 
survey by survey basis. 

If the default status for a newly registered 
survey is 'Active' but a problem occurs when the 
associated database is being accessed, the survey will be 
25 automatically placed in a suspended state with a message, 
indicating that an error occurred linking to the database 
when the survey was being registered. The E-Mail message 
will remain in the in-tray in this case until it is able 
to be processed correctly, or unless its status is 
0 changed to * Terminated ' . 

A survey entry in the Collator's register can be 
deleted if it is old and has been previously terminated. 
If an old response arrives after an entry has been 
deleted the Collator acts as if it is a new survey and 
5 will attempt to re-register the survey and to link to the 
database and process the response, unless the default 
registration option is to set a suspended state. 
Collator Survev 'Cut-Off Lev^l« 
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If the survey is using a pre -populated database 
then the exact number of responses is known and a 
•cut-off* level can be set in terms of either a 
•percentage complete' or a specific number of responses. 
5 If the survey is not using a pre-populated database then 
the "cut-off level can only be set as a specified number 
of responses. 

Once the 'cut-off* level is reached the survey 
status is immediately set to 'suspended'. The 'cut-off 
10 level can be left empty and the Collator will continue to 
process until the survey is manually 'suspended' or 
terminated. 

Collator Database Creation 

An additional feature of the Collator and the 

15 format of the Survey Response Document (SVR) is that the 
database can be re-created from the information in the 
SVR. If the original database was pre-populated the 
fully populated database cannot be re-created, but the 
correct database structure can be reproduced and 

20 Collator, being aware of the 're-creation', can change 
the database 'updates* to 'additions'. 

This has two main advantages: 

If for any reason the original database has been 
corrupted, destroyed or lost, and a sufficient number of 
25 responses has not yet been processed, the Collator can 
re-create the database, and the Author does not have to 
burden the remote users to re -respond to a previous 
survey . 

If the survey instigator is in a location 
30 physically removed from the original database, but wishes 
to run Collator and process the responses, a new database 
can be created. 
Pftllator Options 

The Collator can be set to process continually 
3 5 or to sleep for a range of minutes and then awaken to 
process a specified number of responses only. 
The Collator 'r^alflter' document structure 
WORD wMiif|(^pFSurvevB Number of Surveys 
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10 



WORD wSleepMinutes 

WORD wMaximumGrab 

WORD vrDBNumOfRetries 

WORD wDBRetryWait 

STRING BtrSVQPathName 

BOOLEAN bSortByName 

BOOLEAN bAscending 

BOOLEAN bHideTerminated 

BOOLEAN bSuspendOnRegister 

DATETIME LastScan 

ARRAY SurveyRegister 



num of minutes to arleep 

max num SVRs to process 

max ODBC retries 

100th sees between retries 

SVQ directory name 

sort by name or date 

sort ascending or descending 

hide terminated from display 

suspend on registration 

timestanqp of last scan 

array of Survey info 



15 



20 



25 



30 



35 



The Survey Register Structure 

WORD wSurveyStatus 

WORD wtotalResponses 

WORD wPr oce s sedRe sponses 

WORD wDeletedResponses 

WORD wTotalRows 

WORD wCutOff Count 

BOOLEAN bRecreatedDatabase 

BOOLEAN bPrePopulated 

BOOLEAN bRetainAfterReply 

DATETIME tmRegistered 

DATETIME tmCurrentStatus 

DATETIME tmLastRead 

DATETIME tmRemind 

DATETIME tmResend 

STRING strSVQPileName 

STRING strSurveyName 

STRING strTableName 

STRING strDataSetName 

STRING strDataSetConnection 
ARRAY 



Status of the survey 
total SVRs received 
number SVRs processed 
number SVRs deleted 
pre-populated total 
holds cut off level 
indicates DB recreation 
indicates pre-populated DB 
indicates SVQ is kept 
timestamp when registered 
timestamp of current status 
timestanqp of last SVR read 
timestamp of last Reminder 
timestamp of last Resend 
name of SVQ file 
full SVM pathfilename 
Name of the Table 
Data Set Name (DSN) 
Full DSN Connect string 
Available Data Types Array 



DataSetDataTypeArray 
The above -described modules access 3 document 
file formats collectively known as the Survey Documents 

1. the Survey Master Document (SVM), 

2. the Survey Questionnaire Document (SVQ), 
and 
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3 . the Survey Response Document (SVR) . 

The design of these Survey Documents underpins 
the preferred embodiment. Whilst the preferred 
embodiment is implemented for MS Windows the design of 
the Survey Documents could easily be transferred to any 
computer system. The Survey Master Document (SVM) 
contains the Survey Questionnaire Document (SVQ) , and 
also contains additional survey 'author' information not 
required in the questionnaire (SVQ) section. The Survey 
Response Document (SVR) , contains the answers and 
sufficient information to link to the database and 
sufficient information to re-create the database in the 
case of a catastrophic error. 
The Survey Master Document (SVM) 

The SVM is composed of four main sections: 

1. The Survey Questionnaire Document (SVQ) ; 

2. Subject and Note Texts; 

3. Array of Recipients; and 

4. Document defaults and options. 
I) Suirvey Questionnaire Document (SVQ) 

The following lists the document variables in order 
String strSurveyMasterPathName PathName of this survey - 

long name for document 

bFlagPrePopulate 
bPlagRetaixoAfterReply 
bFlagFollowUp 



BOOLEAN 
BOOLEAN 
BOOLEAN 
String 
String 



FirstQuestionName 
SelectedQuestionName 



30 String NextQuestionName 

WORD NumOfQuestions 

Strut ReplyToInfo 

35 String strTableName 

String strDataSetName 

String strDataSet Connect ion 

Array DataSetDataTypeArray 



Pre -populate Database 
Retain SVQ after Reply 
Indicates secondary Survey 
The first one to start with 
Currently selected Question 
Name 

Next Question Name to be 
selected 

Number of Questions in the 
survey 

The Collator's mail address 

Name of the Table 

Data Set Name (DSN) 

Full DSN Connection string 

Array of Data Types 
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available 

Array QuestioneArray Each element is a 

"QuestionBox* 
The following is a description of the document 

5 variables . 

The strSurveyMasterPathName is the full pathname 
of the survey master document itself. 

The bFlagPrePopulate indicates that a pre- 
populated database is being used. The default value of 
10 this flag is False. If True this flag has several 
implications; 

1. the Survey Authoring Module will create and 
pre*populate the database with the E-Mail 
name and address, default mail received 

15 date and each question's 'bypass' values; 

2. the Respondent Module will set the Survey 
Response Document (SVR) to 'update* and not 
'insert' records to the database; 

3. the Collating Module responds to received 
20 SVR with this flag set to true by 

displaying percentage received figures as 
well as numbers of responses received. 
Also the Collating module allows the use of 
•reminds- and re-sends' if this flag is set 
25 • to true; and 

4. all three modules are aware that if this 
flag is set then the index on the database 
is unique only on the name and address, and 
does not include the mail received date. 

30 Equally, if this flag is false it indicates 

to all three modules that the database is 
indexed on name, address and mail date 
received, so as to allow multiple responses 
from each respondent. 
35 The bFlagRetainAfterReply indicates to the 

Respondent Module that it should indicate to the remote 
user to keep the current Survey Questionnaire Document 
(SVQ) rather than delete it on completion. The default 
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State of this flag is false. 

The bFlagFollowl^ indicates to the all modules 
that some of the mail addresses being used are from 
previous surveys and may no longer be valid on 
5 completion. The default state of this flag is false. 

The FirstQuestionName stores the name of the 
question to be first selected from the QueetionsArray. 

The SelectedQuestionName is simply a current 
storage place for the name of the current Question. 
10 The NextQuestionName is loaded by the control 

logic with the name of the next Question to select. 

The NumOfQuestions is simply a storage area to 
record the number of Questions in the survey. 

The ReplyToInfo structure contains the E-Mail 
15. name and address to reply to the Collator via the E-Mail 
system. The structure contains: 

String MailName 

String MailAddress 

LONG MailEntrylDSize 
20 Array MailEntrylDData 

The fields are specific to MS Mail, but can be 
extended for any electronic mail or electronic bulletin 
board systems. The purpose of these fields is to store 
the Collator's mail address in the message that is sent 
25 to the Respondents. Note the Collator's mail address may 
not be the same as the Author's mail address (see 
previous description). The Author selects the Collator's 
mail address just prior to the Survey Document being sent 
to the Respondents. 
30 The strTableName contains the name of the table 

to use within the specified database. 

The strDataSetName contains the DSN that 
specifies on the local user's computer which database to 
use. The DatabaseSystem is specific to MS ODBC, but can 
35 be extended for any database system. 

The strDataSetConnection contains the full ODBC 
connection string that is the complete identification 
string required to access the ODBC database. 
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The DataSetDataTypeArray ia a list of the data 
types available for the chosen database. This 
information is used in the creation of the database. 

The QuestionsArray is an Array of Question Box 
5 structures which contain all necessary information to 

present a question to the remote user. The * Quest ionBox' 
structure is explained after the description of the 
Survey Document's main sections (see "The Question Box 
Structtire* below) . 

10 Note: the Question Box array is accessed by use 

of the desired Question Box's RefNaroe'; equally when a 
Question Box is placed in the array the 'RefName* is 
extracted from the Question Box structure and used as the 
index associated with the array. 

15 Note that the bFlagPrePopulate flag is set to 

false where, for exaitple, the Author is sending a survey 
to an electronic bulletin system. 

As has previously been mentioned, application of 
the invention to a "bulletin system" would involve 

20 posting a Survey Questionnaire Document (SVQ) on a 

"bulletin board" for selection and answer by any user 
having access to the bulletin board. That is, the users 
would not be preselected for the Survey Document to be 
sent to. In such a case, the database size would depend 

25 upon the number of answers received to the Survey 
Document . 

As discussed above bPlagRetainAf terReply flag 
when false indicates to the Recipient that it should 
erase the copy of the composite file when the Recipient 

30 has successfully sent back an answer (SVR) . However if 

this flag is false then the SVQ may be preserved and used 
again. The bPlagRetainAf terReply flag when true also 
tells the Author and the Collator that each recipient may 
send more than one answer (SVR) , and therefore an extra 

35 'DateReceived' field is generated in the database. This 
extra field is used to make the answer rows in the 
database unique for indexing purposes, and also to track 
the arrival of each of the multiple answers. 
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This facility ia useful where the local user •may 
require periodic update of the same survey, eg, political 
poling. Out of date information would be overwritten by 
the new information coming in from the remote users, and 
5 the database "date received" field would indicate the 
latest date which an answer has been received from the 
remote . 

3, Subject and Note Texts 

String MailSiabjectText E-Mail Subject Text 

10 String MailNoteText E-Mail Note Text 

The MailToSelection stores the operator's 
selection of who the mail recipients are. 

The MailsiibjectText is a simple one line 
description of the mail being sent to the Recipient. 
15 The MailNoteText is used for a description of 

the survey, read by the Recipient before they begin the 
survey . 

^) Array of Recipients 

The recipients data is exactly the same as reply 
20 to info accept that it is an array of them. 

Array RecipientsArray Each element is a 

"RecipientDate ' 
Again the actual • RecipientDate • structure 
implemented in the current embodiment is specific to MS 
25 mail, but can be extended for any electronic mail system. 

Note this is not a fully expanded list - just 
simply what the operator chose. It may be any 
combination of individuals or E-Mail groups, or the E- 
Mail names and addresses of Respondents from previous 
30 surveys - 

A) Docum ent defaults and options 

WORD wQuestionBoxLef tMargin 

WORD wQuestionBoxTopMargin 
WORD wQuestionBoxWidth 
35 WORD wQuestionBoxHeight 

WORD vrQue s t ionText Width 

WORD wQuestionTextHeight 
WORD wQuestionTextLef tMargin 
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WORD 


wQues t ionText TopMargin 


WORD 


wControlsLeftMargin 


WORD 


wltemsLeftMargin 


WORD 


wCentreQuest ionText 


String 


strNeverSeenValue 


String 


strNeverSeenSelection 


String 


strOptionChosenValue 


String 


BtrOptionChosenSelection 


String 


strCheckBoxTrueValue 


String 


St rCheckBoxTrueSelect ion 


String 


strCheckBoxFalaeValue 


String 


8 1 rCheclcBoxFal sesel ec t ion 


String 


8 1 rNumer i cFi e 1 dType 


String 


StrNumericTypeSelection 


String 


strGotoDlgName 


String 


BtrOotoDlgSelection 



These fields are used as a place to store Author 
defaults for the creation of each of the Question Boxes 
by the Author. They are a convenience for the operator 
20 of the system, but not relevant to this description. 
The Question Boir 

Overvigy 

Prom the Recipient's perspective a Question Box 
is simply a standard graphical user interface 'dialogue 
25 box* with: 

1. The question text in an area at the top of 
the Question Box; 

2. some user controls; either option buttons, 
check boxes, numeric data entry fields, or 

30 text data entry fields; and 

3. two push buttons at the bottom of the 

Question Box, marked 'Previous* and 'Next'. 

The Question Box structure must contain and/or 
achieve the following: 

35 !• Sufficient information to display the 

Question Box via the graphical user 
interface; 

2. define the Question Box's database field's 
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name, type and size in the Author or 
Collator created database; 
store the Recipient's answers in all the 
Question Box's database fields; 
store the • Never-Seen' values as the 
Recipient's answers in all the Question 
Box's database fields if the particular 
question is never asked due to Question Box 
* branching ' ; 

store the 'Branch Control Language' script 
for this particular question if required 
(see later) ; and 

define the name of the next Question Box to 
'goto' depending on the user's current or 
previous answers. 

To achieve this there is a three tiered 



25 



The Question Box or header containing 
several ' GroupData • structures ; 

2 . the ' GroupData ' structures which in turn 
contains several • ControlData ' structures; 
and 

3. the 'ControlData' structure. 

These three structures are detailed after the 
next section. 

ConstantB/definit iona used bv all three structures 

Each control is assigned a 'TYPE' indicator. 
This is used to ensure consistency between the control 
and its Group. The controls are grouped by 'TYPE' . 



30 


define 


CTL- TYPE -NULL 


OxOOOOOOOOL 




define 


CTL-TYPE-QUESTIONTEXT 


OxlOOOOOOOL 




define 


CTL-TYPE-NEXTPREVBUTTONS 


0X20000000L 




define 


CTL - TYPE - OPTIONBUTTONS 


OxOOOOOOOlL 




define 


CTL - TYPE - CHECKBOX 


OX00000002L 


35 


define 


CTL - TYPE - NUMER I C 


OX00000004L 




define 


CTL-TYPE-TEXT 


0X0O00OO08L 



These defines indicate the 'TYPE' of each Group. 
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GRP- 


•TYPE- 




0X0000000 


define 


GRP- 


■TYPE- 


-QUESTIONTEXT 


OxlOOOOOOOIi 


define 


GRP- 


TYPE- 


-NEXTPREVBUTTONS 


OX20000000L 


define 


GRP- 


TYPE- 


-OPTIONSBUTTOMS 


OXOOOOOOOIL 


define 


GRP- 


•TYPE- 


-CHECKBOX 


OX00000002L 


define 


GRP- 


•TYPE- 


-NUMERIC 


OX00000004L 


define 


GRP- 


TYPE- 


•TEXT 


OX00000008L 


define 


GRP-TYPE- 


-GRID 


OxOOOOOlOOL 



The Question Box needs to indicate what 'TYPBs* 
10 of group/controls it contains. Note; 

1. The first 4 are single types. 

2. The 'GRID' is used in conjunction with the 
first 4 TYPES to indicate which TYPE of 
'grid* it is. 

15 define DLG-TYPE-NULL 
define DLG-TYPE-BASE 
only PUSHBUTTONS & STATICTEXT 



OxOOOOOOOOL 
0X30000000L 



def ine DLG - TYPE - F INI SH 
only PUSHBUTTONS & STATICTEXT 



OX30000000L 



20 define DLG- TYPE -OPTIONBUTTONS 

define DLG -TYPE -CHECKBOX 

define DLG -TYPE -NUMERIC 

define DLG-TYPE-TEXT 

define DLG-TYPE-GRID 



OxOOOOOOOlL 
OX00000002L 
OX00000004L 
0X00000008L 
OxOOOOOlOOL 



25 



of TYPES i 



Following defines are for masking out the 3 sets 



define STANDARD -TYPES -MASK OxFOOOOOOOL 
Standard (StaticText & PushButtons) 

define ACTIVE -TYPES -MASK OxOOOOOOFFL 
30 Active (Option^ Check, Numeric, Text) 



define COMPLEX -TYPES -MASK OxOOOOFFOOL 
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Conqplex (Grid and Combo indicators) 



10 



15 



20 



25 



The ControlData Structure 

The ControlData structure is mainly concerned 
with displaying the controls within the Question Box's 
dialogue; therefore they are based on MS Windows 
ControlData structure. However it is the additional 
fields that are important, as each graphical user 
interface will store its control's data slightly 
dif ferently. 

Also please note the standard MS Windows IDOK 
define is allocated to the 'Next' button, and the 
IDCANCEL to the 'Previous* button. This is pure 
convenience - amy define will do. 
Attributes as per MS Windows structure 



WORD wX 

WORD wY 

WORD wWidth 

WORD wHeight 

WORD wControlID 

DWORD IControlStyle 



BYTE bClassID 

String ControlText 

BYTE bBy te sToNext Control 



X pos in dig units 

Y pos in dig units 

Width in dig units 

Height in dig units 

ID for messages from the 

control 

Window Style - 
Option/Check, Default, 
Group etc 

Class ID * Button, Edit, 
Static, etc 
Control Text 
Always null 



30 



Attribute s additional to MS Windows structure 



DWORD iControlType 



String FieldValueSelected 



String ItemLabel 



35 String GotoQuestionName 



Type of Control (Option 
Button, Check Box, etc) 
Value of database -field if 
this Control is selected 
Name used to reference the 
control through the BCL 
See explanation below 



The IControlType is used to cross check the 



SUBSmviS SHEET (Rate 



W09M8779 



- 63 • 

control within the parent group structure. 

The PieldValueSelected holds the value to place 
in the database field should Control be selected by the 
Recipient's operator. Note this is only applicable to 
Option Buttons and Check Boxes, as Numeric Field and Text 
Field entries are not predetermined. The database field 
itself is in the parent group structure. 

The ItemLabel field is used to name the control 
(•item* in the Author operators menu) so that it can be 
referenced by the 'Branching Control Language* (BCL - see 
later) . The ItemLabel must be uniquely named within the 
Question Box but does not have to be unique across the 
whole Survey Document. The Author module will produce 
default labels based on the item type (Option Button, 
Check Box, Numeric Field, etc) and its sequence number 
within the Question Box. 

The 'GotoQuestionName* field is known by four 
different names when referred to from outside the 
ControlData structure. These are: 

1. GotoQuestionName if the Control TYPE for 

this is a CTL-TYPE- 
OPTIONBUTTON, then this 
field contains the GOTO 
QuestionName, which will 
placed in the ''Next* 
buttons • NextQuestionName " , 
should the Recipient's 
operator select this 
control . The value 
(RefName) of the 
GotoQuestionName is chosen 
by the Author at design 
time. 

2. NextQuestionName if the Control ID for this 

is 'NEXT' ie Control ID « 
IDOK, then this field 
contains the GOTO Next 
QuestionName - chosen by 
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10 

4 . PieldValueUnChecked 
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the Author at design time 
or by the Recipient at 
runtime (if Option Buttons 
questions) . 

if the Control ID for this 
is 'PREV* ie Control ID - 
IDCANCELi then this field 
contains the previous 
QuestionName that the 
Recipient just came from 
(at runtime) . 
if the Control TYPE for 
this is a CTL-TYPE- 
CHECKBOX, then the GOTO 
Name is Not Used ! However 
an extra *UN-CHECKED* field 
value is required for a 
CheckBox - so this field is 
used to save space. 



20 7hg GroupData Structure 

The GroupData structure is independent from the 
requirements of displaying a dialogue box through the 
graphical user interface. The GroupData structure 
contains all the information about a database field, and 

25 contains an array of the ControlData structures that are 
associated with that database field (which contain or 
will contain the Recipient's answer) . 

Each group contains ONE database -field, so: 
1. There may be MANY Option buttons in a group. 

30 2. There may only be ONE Check box in a group. 

3. There may only be ONE Numeric Data Field in a group. 

4. There may only be ONE Text Data Field in a group - 
Attributes 

DWORD IGrpType 
35 Specifies Group Type - Option, Check, Numeric, Text 

CString DataBaseFieldName 
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DataBase Field Name for this group of control (s) 

WORD wDataBaseFieldType 
DataiBase Field Type 

WORD wDataBaseFieldLength 
5 DataBase Field Length 

String NeverSeenFieldValue 

Value for database field if never displayed to Recipient 
String Result ant FieldValue 

Final Value for database field when selections made 

10 WORD wSelectedControlID 

ID of the Control the Recipient selected 

BYTE bNumOfControls 
Number of controls in the Group 

Array ControlDataArray 
15 Each element is a * ControlData * 

The IGrpType specifies the Group Type (Option 
Button, Check Box, Numeric Field, etc) and is used as a 
cross check against the Group's ControlData elements. 
The DataBaseFieldName, wDataBaseFieldType, 

20 WDataBaseFieldLength are used in the creation of the 

database by the Author. Also these fields are used by the 
Collator when loading the Recipient's answers into the 
database. The DataBaseFieldName must be uniquely named 
across the whole Survey Document. 

25 The NeverSeenFieldValue holds an Author 

designated value to be placed in the database field if 
the Question Box was never displayed to Recipient. When 
the Recipient first opens the Survey Document then the 
Resultant FieldValue (see next) is pre-loaded with the 

30 NeverSeenFieldValue. Equally the ResultantFieldValue are 
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loaded with the NeverSeenPieldValue if the Recipient "^s 
operator presses the 'Previous* button thereby nullifying 

a selection. 

The ReeultantPieldValue holds the Recipient's 
answer to the question or the NeverSeenPieldValue field 
if the Question Box was never displayed to Recipient. 

The wSelectedControlID holds the binary ID of 
the Control that the Recipient's operator selected. This 
is preserved in the answer document for debugging 
purposes, and allows the Recipient's selections to be 
replayed from the first Question Box. 

The bNumOfControls tells the code accessing the 
Group structure the number of ControlData elements stored 
in the ControlDataArray (see next) . 

The ControlDataArray stores the 'ControlData* 
elements. Note that the mechanisms that store and 
retrieve ControlData elements from/to the 
ControlDataArray does a cross check of the Control's Type 
and the Group's Type. 
The Quest ionBox S tiructure 

The QuestionBox structure is based on MS Windows 
DialogHeader structure. However it is the additional 
fields that are important, as each graphical user 
interface will store its dialogue's data slightly 
differently. 

Attributes as per MS Windows structure 
DWORD 



BYTE 

WORD 

WORD 

WORD 

WORD 

String 

String 

String 



IQuestionStyle 
bNumOfControls 

wX 
wY 

wWidth 

wHeight 

MenuName 

ClassName 

Caption 



Specifies the Dialogue's- 
Window Style 

Number of controls in the 
dig box 

X pos in dig units 
Y pos in dig units 
Width in dig units 
Height in dig units 
Menu Name - usually nul 
Class Name - usually nul 
Title / Caption on the dig 
window 
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10 



20 



25 



30 



35 



WORD 
String 



wPointSize 
PontName 



Pointsize of loaded font 
Name of loaded font 



Attributes additional to MS Wi ndowB fltrueture 



DWORD 
String 



iQuestionType 
Re f Name 



String 
String 



PrevRefName 



NextRefName 



String GotoScript 



15 WORD 



WORD 



Array 



wQuestionNumber 
wNumOfGroupa 
GroupArray 



Question Box Type 
Question Box 
reference name 
Records where 
Recipient came from 
Records where 
Recipient went to 
Optional *BCL* 
Script to be 
activated by 'Next' 
button. 

Records the Question 
creation sequence 
Number of Groups in 
the Question box 
£ach element is a 
' GroupData ' 

The IQuestionType is used by this embodiment to 
restrict the Group 'TYPES* per Question Box - i.e., only 
one group of Option buttons, or several Check box groups, 
but not a mixture of both. The 'IGrpType' sets the •TYPE' 
of the Group and does not check for conpatibility with 
its parent question box 'TYPE' - this restriction is 
controlled through the Question Box only - allowing for 
extensions to multiple group 'TYPEs' if required for 
other embodiments. 

The RefName is used when accessing the desired 
Question Box within the Question Box array, equally when 
a Question Box is placed in the array the 'RefName' is 
extracted from the Question Box structure and used as the 
index associated with the array. 

The PrevRefName is used to store which 
•previous' Question Box's RefName the Recipient came 
from, so that if the Recipient's operator presses the 
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'Previous' button then the Recipient can return to the 
previous Question Box. 

The NextRefName is used to store which 'next' 
Question Box's RefName the Recipient went to. This is 
5 preserved in the answer document for debugging purposes, 
and allows the Recipient's selections to be replayed from 
the first Question Box. 

The GotoScript contains an optional 'BCL* (see 
below) program script to be activated by the •Next* 
10 button. The 'Next' button can either: 

♦ Be loaded with the RefName of the next Question 
Box to branch to. 

♦ Cause (in the case of option buttons) the 
RefName of the next Question Box to be loaded 

3^5 from the selected Option Button's ControlData 

structure . 

♦ Cause « if the GotoScript is not null, the 
GotoScript to read and run to compute the 
RefName of the next Question Box. 

20 Note, that the GotoScript if present will 

override any other goto logic that may have been 
implemented by the Author. 

The wQuestionNuraber records the sequence in 
which the Question Boxes were created, and is used to 
25 construct an initial conqputer generated RefName and 
Caption for each Question Box. 

The wNumOfGroups stores the number of Groups in 
the Question Box's GroupArray. 

The GroupArray contains 'GroupData' elements. 
30 Note that a variety of mechanisms exist for the storing 
and retrieving of GroupData elements in the GroupArray, 
including access with consideration of desired 'TYPE', 
etc. 

Survey Respon fle DocuPient (SVR) 
35 The SRV is fundamentally a stripped down SVQ. 

It will be appreciated that having answered the questions 
we no longer need the question or answer texts. We 
simply need to store the answer values (bypassed or 
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answered) , the database field names « the database field 
types and the database field lengths. The 
strSurveyMasterPathName field of the SVQ is retained as 
it contains sufficient information to identify the Survey 
5 for the Collator's needs. Equally the strTableName, 
strDataSetName , strDataSetConnect ion , and 
DataSetDataTypeArray fields from the SVQ contain 
sufficient information to reconnect to or recreate the 
ODBC database created by the Authoring module. 
10 The Survev Documents various staqea 

This description refers to Figure 13. 

At 103 when the Author operator chooses *Send' 
the Author does the following steps: 

1. The operator is asked to select an E-Mail 
15 address for the Collator, which is stored in the 

ReplyToInfo section of the Survey Questionnaire Document 
(SVQ) stored within the Survey Master Document (SVM) . 

2. The operator is presented with an E-Mail address 
selection dialogue. The operator selects various 

20 individuals and E-Mail groups. These selections are 
placed in the MailToSelection section of the Survey 
Master Document (SVM) . As discussed previously, E-Mail 
addresses of respondents to previous surveys may also be 
selected. 

25 3. The operator is also presented with a Mail 

Subject Text and Mail Note Text dialogue. These fields 
are placed in the Subject and Note Texts section of the 
Survey Master Document (SVM) . 

4. The MailToSelection is decoded by the Author 

30 into individual E-Mail addresses and stored in the Array 
of Recipients section of the Survey Document . 

5. The database is then usually created, its 
reconnection information stored in the strTableName, 
StrDataSetName , strDataSetConnect ion, and 

35 DataSetDataTypeArray section of the Survey Questionnaire 
Document (SVQ) , and a row for each of the Recipients 
(assuming bFlagPrePopulate is true) is preloaded with 
additional fields such as the Recipient's E-Mail name and 
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MalllD, and other fields ae may be set by the Options- 
section of the program. 

€. If there is no room for the full database then 
the operation can be aborted without having sent the 
5 survey . 

7. At this point the Author saves the Survey 
Document with its master extension .SVM. 

At 100 the Survey Questionnaire Document (SVQ) 
section of the Survey Master Document (SVM) is extracted 
10 and written to disk, where it is combined with its 

associated 'methods* (Response Exe) to form a composite 
object (both data and executable code) . The Mail 
Recipients and the Subject and Note texts are copied to 
the mail system for the SVQ to be sent to the 
15 respondents. At this point the SVQ is also mailed to the 
Collator E-Mail address. 

At 105, 106, 107 and 108 assuming remote user 
completes the survey, the Respondent processes the SVQ 
via the following steps: 
20 1. Executes the SVQ which reads itself and presents 

the questions to the remote user, storing the remote 
users answers in SVQ itself. 

2. Builds the Survey Response Document (SVR) from 
information contained within the SVQ. 
25 3. Using the Collator's Mail address information it 

activates the MS Mail transport to send Mail messages 
with the attached SVR. 

At 110 and 111 the Collator processes the SVR 
via the following steps: 
30 1. Reads and processes the Survey Response Document 

(SVR) . 

2. Checks that the answer is still valid for a 
current survey - i.e., that the associated survey exists 
in the Collator's register. 
35 3. Assuming its still valid Collator updates (or 

inserts) the database fields with the appropriate answers 
extracted from each of the Question sections of the SVR. 

4 . Deletes the SVR and the associated message from 
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the Mail q[ueue. 

5. After a certain number or percentage of returned 
answers, the operator will be alerted and may choose to 
texminate the survey by setting its status in the 
Collator's register. After this SVR<s for this 
particular survey will be deleted after being identified 
rather than being fully processed. 

6. Other features exist such as Collator sending 
reminders to non- responding Recipients and also resending 
the complete SVQ again if it has been lost by a 
Respondent . 

Rules 

1- When a new Question Box is added to the Survey 
Document it is created with an area at the top for the 
question text, and two buttons at the bottom labelled 
•Next* and 'Previous', these 3 user interface controls 
are regarded by the design of the Survey Document as non- 
active as they contain no operator selectable answers, or 
database field definition information. 

2. Once a new Question Box is created n the Author 
module it is assigned a type of 'DLG- TYPE -BASE' which is 
a combination of DLG-TYPE QUESTIONTEXT and DLG-TYPE- 
NEXTPREVBUTTONS . 

3. Once a new Question Box is created in the Author 
module with the type of 'DLG-TYPE-BASE' it can become any 
of the active or complex TPBs, however once one control 
is added, the Question Box becomes the TYPE of the first 
active/complex control. If another control type is added 
the question type will reflect that. 

4. When a new Survey Document is created by the 
Author module it is made with a terminating Question Box 
labelled • (FINISH) • . This varies from the normal 
Question Box created in the Survey Document, in that it 
has only one button at the bottom of the Question Box. 
This button is labelled 'Finish', 

5. The Survey Document master SVM is the only 
version of the Survey which can be edited. 

6. The table creation mechanism will not allow two 
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tables with the same name to be created within a 
database. If a Survey Master Document is E-Mailed again 
it must first specify another tablename. This safeguards 
the integrity of the distributed survey- 
5 7. Through the Collator, an operator may set the 

cut-off point based on the number or percentage of 
Recipient's Survey Document answers SVR that it wishes to 
process. At this point the Collator will automatically 
set the status of this particular survey to * suspended'. 
10 Additional answer documents for this survey will remain 
in the 'in-tray' after this point has been reached in 
case the operator wishes to extend their chosen cut-off 
point . 

8. Through the Collator an operator may terminate a 
15 survey by setting its status to 'terminated' in the 

Collator's internal register. As soon as the survey is 
terminated any answer documents for this survey will be 
erased by the Collator module. 
'Branching Co ntrol Language' (BCD 
20 An embodiment may utilise "branching control 

language" to control branching between questions in the 
Survey Document. This is accessed through any given 
question box*s property dialogue and stored in the •Next' 
button's ControlData structure. The 'Next* button can 
25 either: 

♦ Be loaded with the RefName of the next Question 
Box to branch to. 

* Cause (in the case of option buttons) the 
RefName of the next Question Box to be loaded from the 

30 selected Option Button's ControlData structure. 

* CausSf if the GotoScript' is not null, the 
GotoScript to read and run to compute the RefName of the 
next Question. Note if the GotoScript is present it will 
override any other goto logic that may have been 

35 implemented by the Author's operator. 

The BCL allows two methods to access information 
from which to make branching decisions: 

♦ Through the DataBaseFieldName which is uniquely 
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named across the whole Survey Document. 

♦ Through the ItemLabel field which is uniquely 
named within its Question Box. 

The status of any control in any Question Box, 
or, the selected value of any database field can be 
interrogated by the language. 

This script has a fairly simple syntax: 
IF Questions (question reference) . 'item-label* •/<> 
condition 

AND Questions (question reference) . •item-label* =/<> 
condition 

OR Questions (question reference) . 'item- lfiQ>el' -/<> 
condition 

THEN GOTO (specific question reference) 
ELSE GOTO (specific question reference) 
ENDIF 
or: 

IF Database ( •Database Field Name* «/<> value 
AND Database { 'Database Field Name' =/<> value 
OR Database ( 'Database Field Name* «/<> value 
THEN GOTO (specific question reference) 
ELSE GOTO (specific question reference) 
ENDIF 

♦ Where the AND / OR / ELSE sections are optional. 

♦ Where represents equal to, and '<>•* represents 
not equal to. 

♦ Where 'condition* is either 'True / Selected / On / 
ChecJced* or 'False / UnSelected / Off / UnChecJced' . 

♦ Where 'value' is one of the possible values that the 
specific database field can be set to. 

Both the selection status and the selected value 
syntaxes can be mixed together: 

IF Questions (question reference) . 'item- label' =/<> 

condition 

AND Database (' Database Field Name* =/<> value 

THEN GOTO (specific question reference) 
ENDIF 

At least the preferred embodiment enables 
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formulation by the local user of a Survey Document which 
incorporates complex branching pathways between 
questions . 

Generally, any question may include a branch to 
5 any other question in the document, depending on document 
structure design. There may be any number of complex 
pathways through the document, any of which may be 
followed by the remote user, depending upon his given 
answers . 

3^0 The rule is that a question cannot refer to a 

previously answered question, but can branch to all 
others. A branch can be triggered by any preceding 
answer or answers. 

It will be appreciated that the present 
15 invention may vary from the specific features of the 
embodiment disclosed above. The invention has wide 
commercial application for information gathering 
purposes. It enables a user to ask any type of 
questions, any number of questions with any branching 
20 complexity, of hundreds or even thousands of users. 
Responses are automatically processed, the pertinent 
information extracted and loaded into an appropriate 
place in a database which is automatically constructed 
for the local user. The user can then analyse the 
25 information anyway that he likes. 

It will be appreciated by persons skilled in the 
art that numerous variations and/or modifications may be 
made to the invention as shown in the specific 
embodiments without departing from the spirit or scope of 
30 the invention as broadly described. The present 

embodiments are, therefore, to be considered in all 
respects as illustrative and not restrictive. 
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THE ClAIMS DEFINING THE INVENTION ARE AS FOLLOWS : 

1. A system for obtaining information from a 
plurality of computer users: 

comprising a processing apparatus including an 
5 input means via which a survey author may input data, and 
a suxrvey authoring means enabling construction of a 
survey questionnaire document including at least one 
question formulated from data input by the survey authors- 
transmission means for transmitting the survey 
10 questionnaire document to a plurality of respondent 
users ; and 

a processing apparatus including a collating 
means arranged to receive transmissions from the 
transmission means, to identify response documents which 
15 include responses to the at least one question from the 
plurality of respondent users and to load a database in 
accordance with the responses . 

2. A system in accordance with claim 1, wherein the 
survey authoring means is arranged to construct a 

20 database for receiving data base field values in response 
to the at least one question. 

3. A system in accordance with claim 2, wherein 
each field in the database is identified by a "column" 
label associated with the at least one question and a 

25 "row" label associated with the identity of the 

respondent who is providing the response which is loaded 
in the particular field. 

4. A system in accordance with claim 3, wherein the 
collating means is arranged to add the "row" labels in 

30 response to the processing of received responses. 

5. A system in accordance with claim 3, wherein the 
survey authoring means is arranged to construct the data 
base including the "row" label in response to data input 
by the survey author. 

35 6. A system in accordance with any preceding claim 

wherein the survey authoring means enables construction 
of a survey document containing a plurality of questions. 
7. A system in accordance with claim 6, the survey 
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authoring mesms enabling the construction of a survey 
questionnaire document structure in which some or all of 
the plurality of questions are linked^ so that whether or 
not one or more questions are asked of a respondent user 
5 may depend on responses to another or others of the 
plurality of questions and/or whether a question or 
questions are asked of a respondent user. 

8. A system in accordance with claim 6, the survey 
authoring means including a branch control means which 

10 enables construction of the linked survey document 
structure on the basis of data input by the survey 
author, the branch control means including branch control 
operator commands selectable by the survey author to 
govern the linked structure. 

15 9. A system in accordance with any one of claims 3 

to li wherein the sut^ey authoring means is arranged to 
enable preparation of a survey questionnaire document 
which specifies a plurality of allowable answers to the 
at least one question, so that users receiving the survey 

20 document may select at least one of the allowable answers 
as a response. 

10. A system in accordance with claim 3, wherein 
the survey authoring means is arranged to enable 
construction of a survey questionnaire document wherein, 

25 for a question, the plurality of allowable answers are 
specified by an option button grid, having rows and 
columns providing a matrix of cells for selection. 

11. A system in accordance with claim 10, the 
option buttons grid having title heads for each row and 

30 column in the matrix, and wherein a database field value 
to be entered in the appropriate' database field if the 
associated allowable answer is specified, is designated 
from components of the row and/or column head for the 
particular grid cell. 

35 12. A system in accordance with any one of 

claims 9 to 11, wherein the survey authoring means is 
arranged to enable construction of a survey document 
wherein for a question, the plurality of allowable 
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answers are specified by a check box grid or numeric • 
field grid, having rows and columns providing a matrix of 
cells for receiving the allowable answers. 

13. A system in accordance with claim 12, 

5 wherein the grids have row and column heads and wherein 
the survey authoring means is arranged to construct the 
database with a separate column label for each allowable 
answer available in the check box grid or numeric field 
grid, and the column labels are derived from components 
10 of row and/or column heads. 

14. A system in accordance with any one of 
claims 3 to 13, wherein the survey authoring means is 
arranged to enable construction of a survey questionnaire 
document wherein, for a question, an allowable answer is 

15 a text or numeric answer to be input by the responding 
user. 

15. A system in accordance with claim 14, 
wherein the survey authoring means enables the survey 
author to specify an allowable field length for the text 

20 or numeric answer. 

16. A system in accordance with any one of 
claims 3 to 15, wherein the survey authoring means 
enables construction of the survey questionnaire document 
so that if a question is not asked of a responding user a 

25 "never seen" value is included as the database field 

value in the database field for that question for that 

responding user. 

17. A system in accordance with any one of 
claims 9 to 16, wherein the survey authoring means 

30 enables construction of a survey questionnaire document 
wherein, for a question, the allowable answers are 
specified by a mixture of at least two of a numeric field 
grid, option button grid, check box grid, text field and 
numeric field. 

35 18. A system in accordance with any one of 

claims 9 to 17, wherein the survey authoring means 
enables construction of a survey questionnaire document 
wherein, for a question, the allowable answers are 
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specified by a check box or a plurality of check boxes 
and/or an option button or a plurality of option buttons, 

19. A system in accordance with any one of 
claims 3 to 18, wherein the survey authoring means 
enables the survey author to determine the column label 
for a particular question on the basis of data input by 
the survey author. 

20. A system in accordance with any one of the 
preceding claims, wherein the survey authoring means is 
arranged to provide a respondent control means for 
transmission with the survey questionnaire document the 
respondent control means being arranged to control a 
respondent users computer to process the survey 
questionnaire document. 

21. A system in accordance with any one of 
claims 1 to 19 further comprising a respondent processing 
means including a respondent control means arranged to 
control the respondent processing means to process the 
survey questionnaire document. 

22. A system in accordance with any preceding 
claim wherein the processing of the survey questionnaire 
document on a respondent users computer is arranged to 
result in production of a response document including 
responses formulated from data input by the respondent 
user. 

23. A system in accordance with claim 22, 
wherein the produced response document further includes 
an identifier which identifies which survey questionnaire 
document it was produced from. 

24. A system in accordance with claims 22 or 23 
wherein the produced response document further includes a 
database construction means from which the database to be 
loaded with the responses may be constructed. 

25. A system in accordance with any one of 
claims 21 to 23, wherein the processing is arranged to 
automatically transmit the response document to the 
collating means. 

26. A system in accordance with any preceding 
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claim, wherein the tranamiseion means is electronic mail« 
and the survey questionnaire document is transmitted to 
an electronic mail address. 

27. A system in accordance with claim 26, 
wherein the electronic mail address may be a bulletin 
board address and/or electronic mail addresses of 
individuals/groups and/or E-Mail addresses of respondents 
to previous survey questionnaire documents. 

28. A system in accordance with claim 26 or 
claim 27, wherein the survey authoring means is arranged 
to construct the survey questionnaire document to include 
the electronic mail address of the collator means, 

29. A system in accordance with claim 27, 
wherein the processing results when read onto any one of 
claims 22 to 24 in a response document which includes the 
address of the collator or is attached to a mail message 
which includes the address of the collator means. 

30. A system in accordance with any one of 
claims 26 to 29, wherein the collator means is arranged 
to scan all electronic mail received at the processing 
apparatus, for response documents, to identify the 
response documents and to identify and locate the 
database for the particular survey questionnaire and to 
load the database. 

31. A system in accordance with claim 30, 
wherein the collation means is arranged to identify 
electronic mail addresses of respondent users from 
response documents and/or messages accompanying response 
mail and to load the database with the E-Mail addresses. 

32. A system in accordance with any preceding 
claim, further including a scan test means arranged to 
scan a survey document to test for errors in the 
construction of the survey document, and to notify the 
survey author of any errors. 

33. A processing apparatus for enabling 
construction of a survey questionnaire document, 
comprising an input means via which a survey author may 
input data, a survey authoring means enabling 
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construction of a survey questionnaire document including 
at least one question formulated from data input by the 
survey author and a location address of a processing 
apparatus including a collator means arranged to collate 
response documents produced by respondent users 
processing the survey questionnaire document. 

34 . A processing apparatus in accordance with 
claim 33, wherein the survey authoring means includes any 
or all of the features of the survey document preparation 
means of the system of any one of claims 1 to 32, as 
those features are defined in any one of claims 1 to 32. 

35. A survey questionnaire document structure, 
the document being employable by digital document 
processing systems to gather information from a plurality 
of respondent computer users, the document structure 
including ; 

a location address for a collation means for 
receiving response documents to the survey questionnaire 
document from respondent users; and 

instructions enabling control of a computer to 
display one or more questions to be answered by a user. 

A system in accordance with claim 29, wherein 
the processing results in a response document which 
includes the identity and address of the database. 

36. A survey questionnaire document structure « 
wherein the instructions are arranged to enable 
controller computer to selectively display the one or 
more questions independent of whether or not another 
questions or questions has been displayed to the user 
and/or responses given to another or other questions by 
the respondent user. 

37. A processing apparatus for collating 
response documents received from a plurality of * 
respondent users in response to their receiving a survey 
questionnaire document from a processing apparatus in 
accordance with claims 33 or 34, including a collator 
means arranged to monitor incoming transmissions from a 
transmission means and identify response documents, which 
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include responses and to load a database in accordance 

with the responses. 

38 . A processing apparatus for receiving and 
processing survey questionnaire documents produced by an 

5 apparatus in accordance with claims 33 or 34, including a 
respondent control means arranged to process the survey 
questionnaire document in accordance with data input by a 
respondent user, to produce a response document including 
a response to the at least one question. 

39. A computer -readable memory including a set 
of instructions for enabling a processing apparatus to 
enable construction of a survey questionnaire document, 
the document being employed to gather information from a 
plurality of respondent users, the instructions enabling 

15 the computer to operate as a survey authoring means 

enabling construction of a survey document including at 
least one question formulated from data input to the 
computer by a survey author, and a location address for a 
collation means for receiving and collating response 

20 documents respondent users in response to their 
processing the survey questionnaire document. 

40. A computer- readable memory storing a set of 
• instructions that can be used to direct a processing 

apparatus to operate as a collator means, for collating 
25 response documents in response to a survey questionnaire 
document produced by a processing apparatus in accordance 
with claim 33 or 34, the instructions operating the 
processing apparatus to monitor incoming transmissions 
for response documents, and to load a database in 
30 accordance with responses. 

41. A con5)uter- readable memory storing a set of 
commands that can be used to direct a processing 
apparatus to process a survey questionnaire document 
produced by the apparatus of claims 33 or 34, to produce 

35 a response document including a response to the at least 
one question, to be transmitted on a location for a 
collation means for collating responses. 

42. A method of obtaining information from a 
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plurality of computer users, coit^rising operating a • 
processing apparatus including an input means via which a 
survey author may input data, to construct a survey 
questionnaire document including at least one question 
5 formulated from data input by the survey author, 
transmitting the survey document to a plurality of 
respondent users, and controlling a processing apparatus 
to carry out a collation operation including the steps of 
receiving transmissions from respondent users, 
10 identifying response documents including responses from 
the plurality of respondent users, and loading a database 
in accordance with the responses. 

43. A method in accordance with claim 42, 

further comprising the step of operating a processing 
15 apparatus to automatically construct a database including 
fields for receiving responses to the at least one 
question. 44* A method in accordance with 

claim 43, wherein the step of constructing the database 
includes the step of identifying each field in the 
database by a "column" label associated with the at least 
one question and a "row" label associated with the 
identity of the respondent providing the response loaded 
in the particular field. 

45. A method in accordance with any one of 
claims 42, 43 or 44, the step of constructing the survey 
questionnaire document including constructing it to 
contain a plurality of questions. 

46. A method in accordance with claim 45, the 
step of constructing the survey questionnaire document 
including linking the plurality of questions to each 
other so that whether or not one or more questions are 
asked of the respondent user may depend on responses by 
the respondent user to another or others of the plurality 
of questions and/or whether a question or questions are 
asked of a respondent user. 

47. A method in accordance with claim 46, 
wherein the step of linking a plurality of questions 
includes providing branching control commands with the 
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survey questionnaire document i the branching control 
commands governing the linked structure and being 
selectable by the survey author. 

48. A method in accordance with any one of 

5 claims 44 to 47, wherein the step of constructing the 
survey questionnaire document includes the step of 
specifying a plurality of allowable answers to the at 
least one question, so that respondent users receiving 
the survey document may select at least one of the 
10 allowable answers as a response. 

49. A method in accordance with claim 48, 
wherein the step of constructing the survey questionnaire 
document includes, for a question, the step of specifying 
the plurality of allowable answers by an option buttons 

15 grid, having rows and columns providing a matrix of cells 
for selection. 

50. A method in accordance with claim 49, the 
step of specifying the option buttons grid including 
specifying title heads for each row and column in the 

20 matrix, and the step of designating the database field 
value to be entered in the appropriate database field if 
the associated allowable answer is specified, involves 
formulating the database field value from components of 
the row and/or column head for the particular grid cell. 

25 51. A method in accordance with any one of 

claims 48 to 50, wherein the step of specifying a 
plurality of allowable answers for a question includes 
specifying a check box grid or numeric field grid, having 
rows and columns providing a matrix of cells for 

30 selecting the allowable answers. 

52. A method in accordance with claim 51, 

wherein the step of specifying a numeric field grid or 
check box grid includes the step of specifying row and 
column heads, and wherein the step of constructing the 

35 database includes the step of constructing the database 
with a separate column label for each allowable answer 
available in the check box grid or numeric field grid, 
and deriving the column labels from components of row 
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and/or column heads. 

53. A method in accordance with any one of 
claime 48 to 52, wherein the step of constructing the 
survey questionnaire document involves specifying an 

5 allowable answer as a text or numeric answer to be input 
by the respondent user, and the further step of 
specifying an allowable field length of the for 
the text or numeric answer. 

54. A method in accordance with any one of 
10 claims 48 to 53, wherein the construction of a survey 

questionnaire document includes the step of including a 
command in the survey document that if a question is not 
asked of a responding user, then, on collation, a "never 
seen" value will be included in the database field for 
15 that question for that respondent user. 

55. A method in accordance with any one of 
claims 47 to 54, wherein the step of constructing the 
survey questionnaire document involves specifying, for a 
question, the allowable answers as a combination of at 

20 least two of a numeric field grid, option buttons grid, 
check box grid, or text field. 

56. A method in accordance with any one of 
claims 42 to 55, wherein the step of constructing the 
survey document includes providing a respondent control 

25 means for transmission with the survey questionnaire 

document the respondent control means being arranged to 
control a respondent users computer to process the survey 
questionnaire document. 

57. A method in accordance with any one of 
0 claims 42 to 55, further comprising the step of 

controlling a respondent users computer to process the 
survey questionnaire document. 

58. A method in accordance with claims 56 or 57, 
wherein the step of controlling the respondents terminal 

5 includes processing of the survey questionnaire document 
to produce a response document including a response 
formulated from data input by the respondent user. 

59. A method in accordance with any one of 
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claims 42 to 5B, wherein the step of processing the • 
survey questionnaire document includes providing a 
response document with a database construction means 
which enables a database to be constructed on collation. 

60. A method in accordance with any one of 
claims 57 to 59, including the step of automatically 
transmitting the response document to a location where 
the document will be collated, on completion of the 
processing to produce the response document. 

61. A method in accordance with any one of 
claims 40 to 60, wherein transmissions of the survey 
document and response document are by electronic mail, 
and/or electronic mail addresses of respondents to 
previous survey questionnaire documents. 

62. A method in accordance with claim 61, 
wherein the electronic mail address may be a bulletin 
board address and/or E-Mail addresses of individuals or 
groups . 

63. A method in accordance with claim 62, 
wherein the step of constructing the survey questionnaire 
document includes constructing the document to include 
the electronic mail address of the processing means which 
will carry out collation. 

64 . A method in accordance with any one of 
claims 61 to 63, wherein the step of collating includes 
scanning all electronic mail received at the collation 
means address for response documents, to identify and 
locate the database for the survey and to load the 
database in accordance with the response. 

65. A method in accordance with claim 64, 
wherein the step of collating includes controlling the 
collating processing means to identify electronic mail 
addresses of respondent users from response documents or 
attached messages and to load the database with the 

5 E-Mail addresses. 

66. A method in accordance with any one of 
claims 42 to 65, including the step of operating the 
processing means to scan the survey document to test for 
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errors in the construction of the survey document, and 
notifying the survey author if there are any errors. 

67. A method of controlling a processing 

apparatus to construct a survey questionnaire document 
5 for obtaining information from a plurality of respondent 
users, the method comprising the steps of: 

controlling the processing apparatus to 
construct a survey questionnaire document including at 
least one question formulated from data input to the 
10 processing apparatus by a survey author; and 

to include a location address of a processing 
means for collating responses to the survey from 
respondent users to load a database in accordance with 
the responses. 

15 68. A method in accordance with claim 67, 

wherein the step of constructing the survey questionnaire 
document includes any or all of the steps defined for 
construction of the survey questionnaire document in any 
one of claims '43 to 66 « as those steps are defined in any 

20 one of those claims. 

69. A method of collating response documents 

prepared by respondent users in response to a survey 
document in accordance with claims 67 or 68, the method 
comprising the steps of: 

25 controlling a processing apparatus to monitor 

incoming transmissions to the processing apparatus and 
identify response documents to the survey, and to process 
the response documents to load a database in accordance 
with the responses to the at least one question. 

30 70. A method of controlling a processing 

apparatus to process a survey questionnaire document 
produced in accordance with the method of claims 67 or 
68, to produce a response document formulated from data 
input by a respondent user, the method coiiprising the 

35 steps of: 

controlling the processing apparatus to display 
the at least one question for input of a response by the 
respondent user; and 
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controlling the respondents computer to prepare 
a response document for transmission to the collating 
processor. 
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